强化门户网站建设,网站编辑是什么,游戏app软件开发公司,playyo wordpress一、引入 实际开发中往往需要针对两张甚至更多张数据表进行操作#xff0c;而这多张表之间需要使用主键和外键关联在一起#xff0c;然后使用连接查询来查询多张表中满足要求的数据记录。一条SQL语句查询多个表#xff0c;得到一个结果#xff0c;包含多个表的数据。效率高…一、引入 实际开发中往往需要针对两张甚至更多张数据表进行操作而这多张表之间需要使用主键和外键关联在一起然后使用连接查询来查询多张表中满足要求的数据记录。一条SQL语句查询多个表得到一个结果包含多个表的数据。效率高。
多种连接查询的类型
crossnaturalusingon
二、交叉连接cross join 交叉连接CROSS JOIN是对两个或者多个表进行笛卡儿积操作所谓笛卡儿积就是关系代数里的一个概念表示两个表中的每一行数据任意组合的结果。比如有两个表左表有m条数据记录x个字段右表有n条数据记录y个字段则执行交叉连接后将返回m*n条数据记录xy个字段。笛卡儿积示意图如图所示。 我希望查找员工编号、员工姓名、部门编号和部门名称这4个字段的数据在员工表emp中可以查询到员工编号、员工姓名、部门编号的数据在部门表dept中可以查询到字段部门名称的数据如果想同时查找这些数据需要使用多表查询语法交叉连接cross join
查询员工表emp
select * from emp; 查询部门表dept
select * from dept;一条SQL查询两个表
select * from emp cross join dept; 表emp14条记录表dept4条记录交叉连接查询后14*456条记录交叉连接就是对这两个表进行笛卡尔乘积操作笛卡尔乘积没有实际意义但是有理论意义。
关于交叉连接的写法MySQL中可以省略crossOracle中不可以省略不写上条SQL等价于
select * from emp join dept; 三、自然连接natural join
交叉连接会查询到许多冗余数据比如在员工表emp和部门表dept中让主键和外键关联起来的外键deptno没有匹配到一起造成数据冗余 使用自然连接可以自动匹配所有的同名列让同名列只在查询中展示一次提高查询效率
select * from emp natural join dept; 可以指定查询的部分字段
select empno,ename,deptno,dname from emp natural join dept; 当查询一个字段时系统会分别从两个关联的表中查找因此效率较低为解决这个问题我们可以在查询目标字段时指定表名格式为表名.字段名
select emp.empno,emp.ename,emp.deptno,dept.dname from emp natural join dept;
查询结果和上述一致但是查询效率得到了提升。
此时如果表名过长查询的SQL也会过长在查询时我们可以为表起别名
select e.empno,e.ename,d.dname,d.deptno
from emp e
natural join dept d;四、内连接
使用natural join 的缺点会自动匹配表中所有的同名列但是有的时候我们希望只匹配部分同名列那么我们可以使用using子句,这属于内连接inner join
select *
from emp as e
inner join dept as d
using(deptno);
using子句的缺点关联的字段必须是同名的 解决方法使用内连接中的on子句
select *
from emp e
inner join dept d
on (e.deptno d.deptno); 五、总结
多表查询的类型有
交叉连接 cross join自然连接 natural join内连接 - using子句内连接 - on子句
综合来看内连接 - on子句的使用频率最高。
六、补充
select *
from emp e
inner join dept d
on (e.deptno d.deptno)
where sal 3500;
条件 1、筛选条件 where having 2、连接条件 on/using/natural 在SQL99语法当中筛选条件和连接条件是分开的。