目录
左连接(LEFT JOIN或LEFT OUTER JOIN):
右连接(RIGHT JOIN或RIGHT OUTER JOIN):
内连接(INNER JOIN也叫等值连接):
全连接(FULL JOIN):
SQL中的连接主要是将两张表中的数据进行拼接,然后通过语句中的筛选条件进行筛选。
在连接中,无论哪种连接方式,from后边的第一个表名就是主表,主表在连接查询的结果中的字段始终在左边。
现在有两张表,表一有7条数据(id从1到7),表二有8条数据(id为1到9,除去7)
左连接(LEFT JOIN或LEFT OUTER JOIN):
按照左边的数据条数建立连接,左边的每条数据都会去连接右边表的每条数据,最后得到的数据条数就是7*8=56条:
select * FROM product a LEFT JOIN resource b on TRUE
如果加上筛选条件,查找出连接后两边id相等的数据,将会查出7条,上边的例子也讲到了,左连接中,左表的每一条数据都会去连接右边表的每条数据,但是第7条只有表一的数据,表二的数据全部为空,因为表二中没有id为7的数据。
select * FROM product a LEFT JOIN resource b ON a.id = b.id
加上筛选条件就可以查找出左表(a表)独有的:
select * FROM product a LEFT JOIN resource b ON a.id = b.id where b.id is null
同理,将表二作为主表进行左连接按照id相等的条件进行查找,最后查找到的数据数是8条:
select * FROM resource b LEFT JOIN product a ON a.id = b.id
需要注意的是,下面语句默认就是左连接:
SELECT * FROM product a JOIN resource b ON a.id = b.id
右连接(RIGHT JOIN或RIGHT OUTER JOIN):
按照右边的数据条数建立连接,右边的每条数据都会去连接左边表的每条数据,最后得到的数据条数就是8*7=56条:
SELECT * FROM product a RIGHT JOIN resource b ON TRUE
如果加上筛选条件,查找出连接后两边id相等的数据,将会查出8条,右表的每一条数据都会去连接左边表的每条数据,但是第8条和第9条只有表二的数据,表一的数据全部为空,因为表一中没有id为8和9的数据。
SELECT * FROM product a RIGHT JOIN resource b ON a.id = b.id
加上筛选条件就可以查找出右表(b表)独有的:
SELECT * FROM product a RIGHT JOIN resource b ON a.id = b.id where a.id is null
拓展:并集去交集:两表关联,取并集然后去交集。
select * FROM product a LEFT JOIN resource b ON a.id = b.id where b.id is null
union
SELECT * FROM product a RIGHT JOIN resource b ON a.id = b.id where a.id is null
内连接(INNER JOIN也叫等值连接):
只有两张表中有相同id的数据才会被查找出来,不会出现左连接和右连接中的一个数据条部分数据为空的现象:
SELECT * FROM product a INNER JOIN resource b ON a.id = b.id
全连接(FULL JOIN):
两表关联,查询它们的所有记录:
mysql数据库中不支持full join … on …的写法,但是在Oracle数据库可以这样使用
select a.* FROM(selecttable1.*,table2.*from table1 left JOIN table2 on table1.id=table2 .tid <-- 用左外连接 -->UNION <-- 通过UNION来链接 -->selecttable1.*,table2.*from table1 right JOIN table2 on table1.id=table2 .tid) as a <-- 用右外连接 -->wherea.id = #{id} <-- 如果要根据条件查询,必须要把上面括号里的当做子查询,条件必须写在外面 -->ORDER BY id <-- 其它操作跟在后面 -->