数据库的复杂查询

多表查询/跨表查询
示例:查询所有的员工姓名及其所在部门的名称
SELECT ename,dname FROM emp,dept WHERE deptId=did;


注意:为了防止出现笛卡尔积,在多表查询的时候,需要添加查询条件


问题:无法查询出部门为NULL的员工,也无法查询出没有员工的部门。
解决:
SQL99中的多表查询:
(1)内连接 INNER JOIN .. ON
SELECT ename,dname FROM emp INNER JOIN dept ON deptId=did;
(2)左外连接 LEFT OUTER JOIN .. ON
SELECT ename,dname FROM emp LEFT OUTER JOIN dept ON deptId=did;
(3)右外连接 RIGHT OUTER JOIN .. ON
SELECT ename,dname FROM emp RIGHT OUTER JOIN dept ON deptId=did;

说明:outer关键字可以省略的;
LEFT连接是以FROM后的表格在左,再去dept查找值
RIGHT连接是JOIN后表格为主,去emp查找对应值

(4)全连接 FULL JOIN
MYSQL 不支持全连接


UNION/UNION ALL

UNION ALL 两组数据出现了相同项不合并
UNION 两组数据出现了相同项进行合并

(SELECT …)UNION(SELECT …);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值