连接查询与子查询
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了连接查询与子查询相关的知识,希望对你有一定的参考价值。
连接查询(一次性 查询多个表)
1. 分类
* 内连接
* 外连接
> 左外连接
> 右外连接
> 全外连接(mysql不支持)
* 自然连接(属于一种简化方式)
2. 内连接
* 方言:SELECT * FROM 表1 别名1, 表2 别名2 WHERE 别名1.xx=别名2.xx
* 标准:SELECT * FROM 表1 别名1 INNER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
* 自然:SELECT * FROM 表1 别名1 NATURAL JOIN 表2 别名2
* 内连接查询出的所有记录都满足条件。
例子:打印所有员工的姓名,工资,以及部门名称。(查询所有,记住要考虑外连接比较靠谱)
SELECT e.ename,e.sal,d.dname FROM emp e,dept d WHERE e.deptno=d.deptno SELECT e.ename,e.sal,d.dname FROM emp e INNER JOIN dept d ON e.deptno=d.deptno SELECT e.ename,e.sal,d.dname FROM emp e NATURAL JOIN dept d
3. 外连接
* 左外:SELECT * FROM 表1 别名1 LEFT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
> 左表记录无论是否满足条件都会查询出来,而右表只有满足条件才能出来。左表中不满足条件的记录,右表部分都为NULL
* 左外自然:SELECT * FROM 表1 别名1 NATURAL LEFT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
* 右外:SELECT * FROM 表1 别名1 RIGHT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
> 右表记录无论是否满足条件都会查询出来,而左表只有满足条件才能出来。右表不满足条件的记录,其左表部分都为NULL
* 右外自然:SELECT * FROM 表1 别名1 NATURAL RIGHT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
* 全链接:可以使用UNION来完成全链接
外连接有一主一次,左外即左表为主!即emp为主表,那么主表中所有的记录无论是否满足条件,都打印出来。
当不满足条件时,右表部门使用NULL来补位。
SELECT e.ename,e.sal,d.dname FROM emp e LEFT OUTER JOIN dept d ON e.deptno=d.deptno
右外连接,
SELECT e.ename,e.sal,d.dname FROM emp e RIGHT OUTER JOIN dept d ON e.deptno=d.deptno
全连接
SELECT e.ename,e.sal,d.dname FROM emp e LEFT OUTER JOIN dept d ON e.deptno=d.deptno UNION SELECT e.ename,e.sal,d.dname FROM emp e RIGHT OUTER JOIN dept d ON e.deptno=d.deptno
子查询
:查询中有查询(查看select关键字的个数!)
1. 出现的位置:
* where后作为条件存在
* from后作为表存在(多行多列)
2. 条件
* (***)单行单列:SELECT * FROM 表1 别名1 WHERE 列1 [=、>、<、>=、<=、!=] (SELECT 列 FROM 表2 别名2 WHERE 条件)
* (**)多行单列:SELECT * FROM 表1 别名1 WHERE 列1 [IN, ALL, ANY] (SELECT 列 FROM 表2 别名2 WHERE 条件)
* (*)单行多列:SELECT * FROM 表1 别名1 WHERE (列1,列2) IN (SELECT 列1, 列2 FROM 表2 别名2 WHERE 条件)
* (***)多行多列:SELECT * FROM 表1 别名1 , (SELECT ....) 别名2 WHERE 条件
例子1:查询本公司工资最高的员工的详细信息(子查询,出现的位置:where后作为条件存在)
SELECT * FROM emp WHERE sal=(SELECT MAX(sal) FROM emp );
例子2:(子查询,出现的位置: from后作为表存在)
SELECT e.empno,e.ename FROM (SELECT * FROM emp WHERE deptno=30) e
例子3:打印本公司高于平均工资的所有人
SELECT * FROM emp WHERE sal>(SELECT AVG(sal) FROM emp)
以上是关于连接查询与子查询的主要内容,如果未能解决你的问题,请参考以下文章