sql语句中join ,left join ,right join有什么区别

问题描述:

sql语句中join ,left join ,right join有什么区别
我试着吧一条sql多表查询语句join换成left ,查询的数据一下变多了很多
1个回答 分类:综合 2014-11-04

问题解答:

我来补答
left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录.
right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录.
inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行.
full join:外连接,返回两个表中的行:left join + right join
cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数.
declare @a table(a int,b int)
declare @b table(a int,b int)
insert @a values(1,1)
insert @a values(2,2)
insert @b values(1,1)
insert @b values(3,3)
select * from @a
select * from @b
--左:
select * from @a Aa left join @b Bb on Aa.a=Bb.a
--右:
select * from @a Aa right join @b Bb on Aa.a=Bb.a
--内
select * from @a Aa inner join @b Bb on Aa.a=Bb.a
--外:
select * from @a Aa full join @b Bb on Aa.a=Bb.a
--交叉连接
select * from @a cross join @
 
 
展开全文阅读
剩余:2000
上一页:指函数和对函数
下一页:字丑请见谅。