数据库 left join(或者left outer join),right join(或者right outer join),inner join用法举例
来源:互联网 发布:ubuntu 目录结构 编辑:程序博客网 时间:2024/04/29 22:39
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并不以谁为基础,它只显示符合条件的记录.
0 0
- 数据库 left join(或者left outer join),right join(或者right outer join),inner join用法举例
- JOIN用法 INNER JOIN/LEFT JOIN/RIGHT JOIN/OUTER JOIN
- left join,right join,inner join,outer join的用法
- inner join&left outer join&right outer join
- inner join&left outer join&right outer join 区别
- left outer join,inner join,right outer join的区别
- inner join&left outer join&right outer join
- inner join, left outer join, right outer join
- inner join,outer join,left join,right join的区别
- inner join,outer join,left join,right join的区别
- inner join,outer join,left join,right join的区别
- left join , right join , full outer join , inner join
- Inner join,outer join,left join,right join的区别
- Inner join,outer join,left join,right join的区别
- cross join & natural join & inner join & left outer join & right outer join & full outer join
- SQL join,left join ,right join , inner join , outer join用法解析及HIVE join 优化
- Linq语句实现(INNER JOIN、LEFT OUTER JOIN、RIGHT OUTER JOIN、FULL OUTER JOIN、CROSS JOIN)
- left outer join right outer join
- 补血的食物有哪些?
- 成为谷歌软件工程师你需要准备什么?
- 水仙花数
- maven项目构建出现Unknown lifecycle phase "build".提示解决方法
- Linux密钥验证
- 数据库 left join(或者left outer join),right join(或者right outer join),inner join用法举例
- Java EE13种技术
- The Dragon of Loowater
- 将两句话复制到一个字符串中显示
- 第十三周字符串1
- Android实例demo8之Sqlite的使用(sql语句、android api)
- HashMap源码分析
- nyoj.199 无线网络覆盖【水题】 20141125
- 第十三周项目4:数组的排序