黑马程序员技术交流社区
标题:
数据库 join问题
[打印本页]
作者:
唐海军
时间:
2012-12-20 16:18
标题:
数据库 join问题
数据库中有 join, left join ,right join 他们的区别和用法有啥不同和相同?
作者:
王晨
时间:
2012-12-20 16:41
本帖最后由 王晨 于 2012-12-20 16:54 编辑
left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。
sql语句如下: (假如有A、B两张表)
select * from A left join B on A.aID = B.bID
复制代码
right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。
sql语句如下: (假如有A、B两张表)
select * from A right join B on A.aID = B.bID
复制代码
所以,总的说来:左连接where只影向右表,右连接where只影响左表。
作者:
徐威
时间:
2012-12-20 20:12
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
复制代码
left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。
right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。
inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行。
full join:外连接,返回两个表中的行:left join + right join
cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2