关系数据操作
合并查询数据记录
在MySQL中通过关键字UNION来实现并操作,即可以通过其将多个SELECT语句的查询结果合并在一起组成新的关系。
两张表,表1 和表2
带有关键字UNION的合并操作
关键字UNION会把查询结果集直接合并在一起,同时将会去掉重复数据记录
select name,sex from employee UNION select name,sex from employee_1
查询出来7条数据,经过了去重
带有关键字UNION ALL的合并操作
关键字UNION ALL会把查询结果集直接合并在一起。
select name,sex from employee UNION ALL select name,sex from employee_1
内连接查询
在MySQL中内连接数据查询通过SQL语句INNER JOIN...ON
来实现。
select field1 field2 ...fieldn from join_tablename1 inner joinjoin_tablename2 [inner join join_tablenamen] on join_condition
自连接
内连接查询中存在一种特殊的等值连接 - 自连接,所谓自连接就是指表与其自身进行连接。
雇员表
- empno 雇员ID
- ename 雇员姓名
- job 雇员职位
- mgr 雇员上级领导ID
- sal 雇员薪资
- deptno 雇员部门
现在就是需要查询出雇员的上级领导是谁
select e.empno,e.ename,e.job,e.sal,l.ename as mgrname from employee e inner join employee l on e.mgr= l.empno
等值连接
内连接查询中的等值连接,就是在关键字ON后的匹配条件中通过关系运算符(=)来实现等值条件。
一张部门表
- deptno 部门ID
- deptname 部门名称
查询每个雇员的姓名、部门
select e.ename,e.job,e.sal,d.deptname from employee e inner join dept d on e.deptno= d.deptno
上述连接也可以使用ANSI
连接语法形式
select e.ename,e.job,e.sal,d.deptname from employee e , dept d where e.deptno= d.deptno
不等连接
内连接查询中的不等连接,就是在关键字ON后的匹配条件中通过除了等于关系运算符来实现不等条件外,可以使用的关系运算符包括“>”、“>=”、“<”、“<=”和“!=”等运算符号。
外连接查询
在MySQL中,外连接查询会返回所操作表中至少一个表的所有数据记录。
select field1 field2 ...fieldn from jon_tablename1 left | right | full [outer] join join_tablename2
on join_condition
左外连接
外连接查询中的左外连接,就是指新关系中执行匹配条件时,以关键字left join左边的表未参考表。
上述等值连接中,只有三条数据,但是如果我改成左外连接
select e.empno,e.ename,e.job,e.sal,l.ename as mgrname from employee e left join employee l on e.mgr= l.empno
这边没有匹配上也能全部显示出来。
右外连接
外连接查询中的右外连接,就是值新关系中执行匹配条件时,以关键字right join右边的表未参考表。但是跟左外连接是一个意思,换个位置的事情。
左外连接:
- 左外连接以左表为基准,返回左表中的所有记录,并将符合联接条件的右表记录合并。
- 如果左表中的记录在右表中没有匹配的记录,则右表中的列值将被设置为NULL。
左外连接可以通过使用LEFT JOIN关键字来执行。
右外连接:
- 右外连接以右表为基准,返回右表中的所有记录,并将符合联接条件的左表记录合并。
- 如果右表中的记录在左表中没有匹配的记录,则左表中的列值将被设置为NULL。
右外连接可以通过使用RIGHT JOIN关键字来执行。
总之,左外连接和右外连接的区别在于联接的基准表不同。左外连接返回左表的所有记录,而右外连接返回右表
全外连接
它将两个表中的所有记录都进行匹配,并返回包含两个表中所有记录的结果集。当两个表中的主键不匹配时,返回的结果集中会包含NULL值。
FULL JOIN的语法通常如下:
SELECT * FROM table1 FULL JOIN table2 ON table1.column = table2.column;
这将返回一个包含table1和table2中所有记录的结果集,无论是否存在匹配项。如果没有匹配项,返回的结果集中对应的列值为NULL。FULL JOIN可以用来查找两个表中的所有数据,并比较它们之间的关系。
但是我发现我的MySQL 5.7.14版本竟然不能使用。
那可以考虑这么使用
SELECT * FROM Table1 A LEFT JOIN Table2 B ON A.id=B.id
UNION
SELECT * FROM Table1 A RIGHT JOIN Table2 B ON A.id=B.id
SELECT * FROM employee A LEFT JOIN dept B ON A.deptno=B.deptno
UNION
SELECT * FROM employee A RIGHT JOIN dept B ON A.deptno=B.deptno