1. 多表关系
项目开发中,在进行数据库表结构设计时,会根据业务需求及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在着各种联系,基本上分为三种:一对多(多对一)、多对多、一对一
概述:多表查询就是指从多张表中查询数据。
原来查询单表数据,执行的SQL形式为:select * from emp;那么我们要执行多表查询,就只需要使用逗号分隔多张表即可,如: select * from emp , dept;
# 单表查询
select * from emp;
# 多表查询 -- 笛卡尔积
select * from emp, dept;
# 消除笛卡尔积
select * from emp, dept where emp.dept_id = dept.id;
2. 连接查询
2.1 内连接(交集)
概述:相当于查询A、B交集部分数据外连接
隐式内连接:
语法:
select 字段列表 from 表1 , 表2 where 条件 ... ;
-- 内连接(交集)
# 链接条件 emp.dept_id = dept.id
# 隐式内连接
select emp.name,dept.name from emp,dept where emp.dept_id = dept.id;
# 表取别名
select e.name,d.name from emp e,dept d where e.dept_id = d.id;
显式内连接:
语法:
select 字段列表 from 表1 [ inner ] join 表2 on 连接条件 ... ;
# 显式内连接,关键字...inner join...on...
select e.name, d.name from emp e inner join dept d on e.dept_id = d.id;
select e.name, d.name from emp e join dept d on e.dept_id = d.id;
2.2 外连接
左外连接:
概述:查询左表所有数据,以及两张表交集部分数据右
语法:select 字段列表 from 表1 left [ outer ] join 表2 on 条件 ... ;