A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 唐海军 中级黑马   /  2012-12-20 16:18  /  2031 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

数据库中有 join,  left join ,right join 他们的区别和用法有啥不同和相同?

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

2 个回复

正序浏览
  1. declare @a table(a int,b int)
  2. declare @b table(a int,b int)

  3. insert @a values(1,1)
  4. insert @a values(2,2)
  5. insert @b values(1,1)
  6. insert @b values(3,3)
  7. select * from @a
  8. select * from @b
  9. --左:
  10. select * from @a Aa left join @b Bb on Aa.a=Bb.a
  11. --右:
  12. select * from @a Aa right join @b Bb on Aa.a=Bb.a
  13. --内
  14. select * from @a Aa inner join @b Bb on Aa.a=Bb.a
  15. --外:
  16. select * from @a Aa full join @b Bb on Aa.a=Bb.a
  17. --交叉连接
  18. select * from @a  cross join @b
复制代码
left join   :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。
right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。
inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行。
full join:外连接,返回两个表中的行:left join + right join
cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
本帖最后由 王晨 于 2012-12-20 16:54 编辑

left join   :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。
sql语句如下: (假如有A、B两张表)
  1. select * from A left join B  on A.aID = B.bID
复制代码
right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。
sql语句如下: (假如有A、B两张表)
  1. select * from A right join B  on A.aID = B.bID
复制代码
所以,总的说来:左连接where只影向右表,右连接where只影响左表。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马