SQL中INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN区别
2015-06-03 22:17
513 查看
sql中的连接查询有inner join(内连接)、left join(左连接)、right join(右连接)、full join(全连接)四种方式,它们之间其实并没有太大区别,仅仅是查询出来的结果有所不同。
例如我们有两张表:
Orders表通过外键Id_P和Persons表进行关联。
查询结果集:
此种连接方式Orders表中Id_P字段在Persons表中找不到匹配的,则不会列出来。
查询结果如下:
可以看到,左表(Persons表)中LastName为Bush的行的Id_P字段在右表(Orders表)中没有匹配,但查询结果仍然保留该行。
查询结果如下:
Orders表中最后一条记录Id_P字段值为65,在左表中没有记录与之匹配,但依然保留。
查询结果如下:
查询结果是left join和right join的并集。
这些连接查询的区别也仅此而已。
例如我们有两张表:
Orders表通过外键Id_P和Persons表进行关联。
1.inner join,在两张表进行连接查询时,只保留两张表中完全匹配的结果集。
我们使用inner join对两张表进行连接查询,sql如下:SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons INNER JOIN Orders ON Persons.Id_P=Orders.Id_P ORDER BY Persons.LastName
查询结果集:
此种连接方式Orders表中Id_P字段在Persons表中找不到匹配的,则不会列出来。
2.left join,在两张表进行连接查询时,会返回左表所有的行,即使在右表中没有匹配的记录。
我们使用left join对两张表进行连接查询,sql如下:SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons LEFT JOIN Orders ON Persons.Id_P=Orders.Id_P ORDER BY Persons.LastName
查询结果如下:
可以看到,左表(Persons表)中LastName为Bush的行的Id_P字段在右表(Orders表)中没有匹配,但查询结果仍然保留该行。
3.right join,在两张表进行连接查询时,会返回右表所有的行,即使在左表中没有匹配的记录。
我们使用right join对两张表进行连接查询,sql如下:SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons RIGHT JOIN Orders ON Persons.Id_P=Orders.Id_P ORDER BY Persons.LastName
查询结果如下:
Orders表中最后一条记录Id_P字段值为65,在左表中没有记录与之匹配,但依然保留。
4.full join,在两张表进行连接查询时,返回左表和右表中所有没有匹配的行。
我们使用full join对两张表进行连接查询,sql如下:SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons FULL JOIN Orders ON Persons.Id_P=Orders.Id_P ORDER BY Persons.LastName
查询结果如下:
查询结果是left join和right join的并集。
这些连接查询的区别也仅此而已。
相关文章推荐
- SQL中INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN区别
- oracle存储过程常用技巧
- 再说MySQL中的 table_id
- oracle分层查询中的start with和connect by(树结构查询)
- Oracle学习(16)【DBA向】:Oracle中的导入与导出
- Mysql 压力测试工具super-smack的安装
- corosync +drbd实现HA MariaDB
- Sqlte 知识点记录
- java连接MongoDB查询导出为excel表格
- Java memcache Client 数据操作源码剖析
- ORACLE 11G在同一台linux服务器从实例1全库导入到实例2上
- mysql5.5手册读书日记(1)
- Windows下Mysql数据库服务的关闭和重启
- SQL索引器
- mysql中文乱码的解决方法
- MySQL union all排序问题
- Oracle 数据库PL/SQL ORA -12154 TNS:无法解析指定的连接标识符解决方法
- MySQL常用命令
- oracle锁问题
- 使用Python操作Redis