数据库 left join(或者left outer join),right join(或者right o

php中文网
发布: 2016-06-07 15:30:11
原创
1725人浏览过

sql连接共三种:内连接,外连接,交叉连接。 内连接包含:等连接,不等连接,自然连接 外连接包含:左连接(左外连接),右连接(右外连接) 具体理论见我的博文http://blog.csdn.net/jdfkldjlkjdl/article/details/41485127 -------------------------------------

sql连接共三种:内连接,外连接,交叉连接。

内连接包含:等值连接,不等值连接,自然连接

外连接包含:左连接(左外连接),右连接(右外连接)

具体理论见我的博文http://blog.csdn.net/jdfkldjlkjdl/article/details/41485127

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

下面是实例介绍,相信这样更直观。

现有A和B两个表

表A记录如下: 
aID         aNum 
1            a20050111 
2            a20050112 
3            a20050113 
4            a20050114 
5            a20050115 
表B记录如下: 
bID         bName 
1            2006032401 
2            2006032402 
3            2006032403 
4            2006032404 
8            2006032408 
1.left join(左联接) 
SELECT * FROM a LEFT JOIN b ON a.aID =b.bID 
结果如下: 
aID              aNum              bID            bName 
1                 a20050111     1               2006032401 
2                 a20050112     2               2006032402 
3                 a20050113     3               2006032403 
4                 a20050114     4               2006032404 
5                 a20050115    NULL         NULL 
(所影响的行数为 5 行) 
结果说明: 
left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的. 
换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID = B.bID). B表记录不足的地方均为NULL. 
2.right join(右联接) 
SELECT * FROM a RIGHT JOING b ON a.aID = b.bID 
结果如下: 
aID              aNum              bID            bName 
1                 a20050111     1               2006032401 
2                 a20050112     2               2006032402 
3                 a20050113     3               2006032403 
4                 a20050114     4               2006032404 
NULL           NULL              8               2006032408 
(所影响的行数为 5 行) 
结果说明: 
仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充. 
3.inner join(相等联接或内联接) 
SELECT * FROM a INNER JOIN b ON a.aID =b.bID 
等同于以下SQL句: 
SELECT * FROM a,b WHERE a.aID = b.bID 
结果如下: 
aID             aNum              bID            bName 
1                a20050111     1                2006032401 
2                a20050112     2                2006032402 
3                a20050113     3                2006032403 
4                a20050114     4                2006032404 
结果说明: 
很明显,这里只显示出了 A.aID = B.bID的记录.这说明inner join并不以谁为基础,它只显示符合条件的记录.
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号