您的位置:首页 > 其它

明确一个古老的问题left join,right join,inner join,full join,cross join

2008-07-17 14:09 537 查看
left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。

right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。

inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行。

full join:外连接,返回两个表中的行:left join + right join

cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数。

补充说明:如果表一中的某行对应表二中的两行记录,那么结果集中会有两条记录对应,right 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 @b
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐