明确一个古老的问题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
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
相关文章推荐
- 关于sql的full outer join,left join,right join,inner join, cross join 的说明
- left join,inner join,right join,cross join,full join
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- left join,inner join,right join,cross join,full join的区别
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- inner join,full outer join,left join,right join,cross join
- SQL join、inner join、left join、right join、full join、cross join
- left join,inner join,right join,cross join,full join的区别
- left join,inner join,right join,cross join,full join的区别
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- join连接的五种方式的简单使用案例(Inner join,Left join,Right join,Full join,Cross join)
- SQL中cross join,left join,right join ,full join,inner join 的区别
- left join,inner join,right join,cross join,full join的区别[转载]
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- SQL中cross join,left join,right join ,full join,inner join 的区别
- join连接的五种方式的简单使用案例(Inner join,Left join,Right join,Full join,Cross join)
- sql多表连接查询inner join, left join , right join ,full join ,cross join