在MySQL中通过关键字UNION来实现并操作,即可以通过其将多个SELECT语句的查询结果合并在一起组成新的关系。
两张表,表1 和表2
关键字UNION会把查询结果集直接合并在一起,同时将会去掉重复数据记录
select name,sex from employee UNION select name,sex from employee_1
查询出来7条数据,经过了去重
关键字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 join
join_tablename2 [inner join join_tablenamen] on join_condition
内连接查询中存在一种特殊的等值连接 - 自连接,所谓自连接就是指表与其自身进行连接。
雇员表
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后的匹配条件中通过关系运算符(=)来实现等值条件。
一张部门表
查询每个雇员的姓名、部门
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值。
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