mysql的left join、 right join和inner join
2017-01-22 23:36
369 查看
1.定义
left join:左联接,返回包括左表中的所有记录和右表中符合条件的记录。
right join:右联接,返回包括右表中的所有记录和左表中符合条件的记录。
inner join:等值联接,返回两个表中符合条件的记录。
2. 表的定义
表A记录如下:
aID aNum aheight
1 a20050111 170
2 a20050112 180
3 a20050113 172
4 a20050114 174
5 a20050115 175
表B记录如下:
bID bName bheight
1 2006032401 170
2 2006032402 170
3 2006032403 164
4 2006032404 165
8 2006032408 166
3.查询例子
3.1 left join
select aID , aNum, BID, bName 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
select aID, aheight, bID, bheight from A left join B on A.aheight = B.bheight;
结果如下:
aID aheight bID bheight
1 170 1 170
1 170 2 170
left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的.
换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID = B.bID).
B表记录不足的地方均为NULL.
3.1 right join
right join和left join 刚好相反, 以右边的表为准, 右表将会全部显示出来,而左表只会显示符合条件的记录,不足的地方均为NULL。
3.2 inner join
inner join为等值联接,
select aID , aNum, BID, bName from A inner 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
left join:左联接,返回包括左表中的所有记录和右表中符合条件的记录。
right join:右联接,返回包括右表中的所有记录和左表中符合条件的记录。
inner join:等值联接,返回两个表中符合条件的记录。
2. 表的定义
表A记录如下:
aID aNum aheight
1 a20050111 170
2 a20050112 180
3 a20050113 172
4 a20050114 174
5 a20050115 175
表B记录如下:
bID bName bheight
1 2006032401 170
2 2006032402 170
3 2006032403 164
4 2006032404 165
8 2006032408 166
3.查询例子
3.1 left join
select aID , aNum, BID, bName 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
select aID, aheight, bID, bheight from A left join B on A.aheight = B.bheight;
结果如下:
aID aheight bID bheight
1 170 1 170
1 170 2 170
left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的.
换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID = B.bID).
B表记录不足的地方均为NULL.
3.1 right join
right join和left join 刚好相反, 以右边的表为准, 右表将会全部显示出来,而左表只会显示符合条件的记录,不足的地方均为NULL。
3.2 inner join
inner join为等值联接,
select aID , aNum, BID, bName from A inner 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
相关文章推荐
- mysql left join,right join,inner join用法分析
- mysql中left join,right join,inner join,outer join的区别
- 【sql】mysql left join,right join,inner join超详细用法解析
- MySql学习(三) —— 子查询(where、from、exists) 及 连接查询(left join、right join、inner join、union join)
- mysql中left join,right join,inner join用法
- Mysql 连接(inner join,默认的就是内连接)、外连接(left join,right join)
- Mysql-left join,right join,inner join
- Mysql之inner join,left join,right join详解
- 【sql】mysql left join,right join,inner join超详细用法解析
- mysql中left join,right join,inner join,outer join的用法详解【转】
- mysql left join,right join,inner join用法分析
- mysql的left join和right join和inner join等表联接详解
- mysql中left join ,right join 以及inner join 比较
- Mysql 的内外连接 (inner join,默认内连接) 外连接(left join,right join)
- mysql left join,right join,inner join用法分析
- Mysql之inner join,left join,right join详解
- mysql left join right join inner join例子
- MYSQL用法(二) inner join,left join right join,full join 示例
- mysql的left join,right join,inner join用法分析
- mysql left join,right join,inner join用法分析