首页 > 其他 > 详细

连接查询与子查询

时间:2017-11-02 15:01:27      阅读:282      评论:0      收藏:0      [点我收藏+]

连接查询(一次性 查询多个表)
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)

 

连接查询与子查询

原文:http://www.cnblogs.com/GumpYan/p/7771935.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!