MyException - 我的异常网
当前位置:我的异常网» Sql Server » 多个left join执行顺序解决思路

多个left join执行顺序解决思路

www.MyException.Cn  网友分享于:2014-03-30  浏览:149次
多个left join执行顺序
1. 求教多个left join 怎么执行 
eg:
 select * from a left join b on a.abid = b.baid left join  c  on c.cbid = b.bcid 

2.多个left join连接,记录条数是不是主表的条数 
eg 
  select * from a 
        left join b on a.abid = b.baid 
        left join  c  on c.cbid = b.bcid 
        ...
没有where语句   那么查询出来的结果集条数是不是等于a的记录条数
------解决方案--------------------
先说明2点:
1、left join是逻辑操作符,只用于保证“数据正确”
2、优化器才是最终决定执行顺序的地方,一般来说会按照你的意愿顺序去执行,但是并不完全能保证。

回答你的问题:
1. 求教多个left join 怎么执行 
eg:
 select * from a left join b on a.abid = b.baid left join  c  on c.cbid = b.bcid 
顺序是先a,b组合成一个虚拟表,然后虚拟表再和C表关联

2.多个left join连接,记录条数是不是主表的条数 
eg 
  select * from a 
        left join b on a.abid = b.baid 
        left join  c  on c.cbid = b.bcid 
        ...
没有where语句   那么查询出来的结果集条数是不是等于a的记录条数
左联的意思是返回左表的数据,右表中不能匹配出来的数据以null标识,但是由于你C表是和B左联而不是和A左联,所以数量不一定是A的数量,看清楚,不一定而已
------解决方案--------------------
即使是A LOJ B的结果,记录条数也不一定等于A的记录条数,除非join predicate右边(也就是B表)的列是唯一的。
------解决方案--------------------
引用:
先说明2点:
1、left join是逻辑操作符,只用于保证“数据正确”
2、优化器才是最终决定执行顺序的地方,一般来说会按照你的意愿顺序去执行,但是并不完全能保证。

回答你的问题:
1. 求教多个left join 怎么执行 
eg:
 select * from a left join b on a.abid = b.baid left join  c  on c.cbid = b.bcid 
顺序是先a,b组合成一个虚拟表,然后虚拟表再和C表关联

2.多个left join连接,记录条数是不是主表的条数 
eg 
  select * from a 
        left join b on a.abid = b.baid 
        left join  c  on c.cbid = b.bcid 
        ...
没有where语句   那么查询出来的结果集条数是不是等于a的记录条数
左联的意思是返回左表的数据,右表中不能匹配出来的数据以null标识,但是由于你C表是和B左联而不是和A左联,所以数量不一定是A的数量,看清楚,不一定而已





------解决方案--------------------
关于LEFT JOIN的内容 你可以去看看SQL SERVER 2005技术内幕。

简单的说就是左匹配 如果只有两个表的话,数据确定与左表相同。

如果是多个表的话 按照顺序A,B表先组成虚拟表 然后再一次匹配。
------解决方案--------------------
引用:
关于LEFT JOIN的内容 你可以去看看SQL SERVER 2005技术内幕。

简单的说就是左匹配 如果只有两个表的话,数据确定与左表相同。

如果是多个表的话 按照顺序A,B表先组成虚拟表 然后再一次匹配。


作为左联结果,数据应该是〉=左表。因为当右表的关联字段有重复的话,就会连多了。
------解决方案--------------------
引用:
先说明2点:
1、left join是逻辑操作符,只用于保证“数据正确”
2、优化器才是最终决定执行顺序的地方,一般来说会按照你的意愿顺序去执行,但是并不完全能保证。

回答你的问题:
1. 求教多个left join 怎么执行 
eg:
 select * from a left join b on a.abid = b.baid left join  c  on c.cbid = b.bcid 
顺序是先a,b组合成一个虚拟表,然后虚拟表再和C表关联

2.多个left join连接,记录条数是不是主表的条数 
eg 
  select * from a 
        left join b on a.abid = b.baid 
        left join  c  on c.cbid = b.bcid 
        ...
没有where语句   那么查询出来的结果集条数是不是等于a的记录条数
左联的意思是返回左表的数据,右表中不能匹配出来的数据以null标识,但是由于你C表是和B左联而不是和A左联,所以数量不一定是A的数量,看清楚,不一定而已


版主的意思是:a表先和b表left join 生成虚拟表(假设为T1),b表和c表left join生成虚拟表(假设为T2),最后两个虚拟表怎么办呢?是T1和T2 执行left join吗?
------解决方案--------------------
引用:
Quote: 引用:

先说明2点:
1、left join是逻辑操作符,只用于保证“数据正确”
2、优化器才是最终决定执行顺序的地方,一般来说会按照你的意愿顺序去执行,但是并不完全能保证。

回答你的问题:
1. 求教多个left join 怎么执行 
eg:
 select * from a left join b on a.abid = b.baid left join  c  on c.cbid = b.bcid 
顺序是先a,b组合成一个虚拟表,然后虚拟表再和C表关联

2.多个left join连接,记录条数是不是主表的条数 
eg 
  select * from a 
        left join b on a.abid = b.baid 
        left join  c  on c.cbid = b.bcid 

文章评论

做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
程序员必看的十大电影
程序员必看的十大电影
总结2014中国互联网十大段子
总结2014中国互联网十大段子
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
我是如何打败拖延症的
我是如何打败拖延症的
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
中美印日四国程序员比较
中美印日四国程序员比较
程序员的鄙视链
程序员的鄙视链
旅行,写作,编程
旅行,写作,编程
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
程序员应该关注的一些事儿
程序员应该关注的一些事儿
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
Java程序员必看电影
Java程序员必看电影
漫画:程序员的工作
漫画:程序员的工作
那些争议最大的编程观点
那些争议最大的编程观点
 程序员的样子
程序员的样子
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
程序员和编码员之间的区别
程序员和编码员之间的区别
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
代码女神横空出世
代码女神横空出世
鲜为人知的编程真相
鲜为人知的编程真相
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
如何成为一名黑客
如何成为一名黑客
老程序员的下场
老程序员的下场
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
10个调试和排错的小建议
10个调试和排错的小建议
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
程序员都该阅读的书
程序员都该阅读的书
编程语言是女人
编程语言是女人
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有