SQL中的连接(左、右、内连接) |
您所在的位置:网站首页 › mysql左链接和右链接的区别在哪 › SQL中的连接(左、右、内连接) |
目录 左连接(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只有两张表中有相同id的数据才会被查找出来,不会出现左连接和右连接中的一个数据条部分数据为空的现象: SELECT * FROM product a INNER JOIN resource b ON a.id = b.id两表关联,查询它们的所有记录: mysql数据库中不支持full join … on …的写法,但是在Oracle数据库可以这样使用 select a.* FROM (select table1.*,table2.* from table1 left JOIN table2 on table1.id=table2 .tid UNION select table1.*,table2.* from table1 right JOIN table2 on table1.id=table2 .tid) as a where a.id = #{id} ORDER BY id |
今日新闻 |
点击排行 |
|
推荐新闻 |
图片新闻 |
|
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭 |