鉴于现在每天对web数据库动态更新的需求,研究了下SQL SERVER left join on的用法(本人非DBA,所以可能理解得不是很透彻)
假设现在有两张表:
playerscore playerID

1.先来谈下left join on where
select * from playerscore left join playerID on playerscore.player = playerID.player where playerID.ID='24'
中间表
on条件:
playerscore.player = playerID.player

再对中间表过滤
where 条件:
where playerID.ID='24'
![]()
2.再来谈下left join on and
select * from playerscore left join playerID on playerscore.player = playerID.player and playerID.ID='24'
(条件不为真也会返回左表中的记录)

其实以上结果的关键原因就是left join,right join,full join的特殊性,不管on上的条件是否为真都会返回left或right表中的记录,full则具有left和right的特性的并集。 而inner jion没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。
版权声明:本文为u012464951原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。