扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
作者:论坛整理 superhasty 来源:天新网 2008年4月23日
关键字: 数据库 Mssql SQL SQL Server
5.1 执行全表选取或者低选择性选取
执行SQL:
以下是引用片段: Select * From P_Order A Inner merge JOIN P_User B ON A.MobileNo=B.MobileNo |
逻辑读数近似等于两张表的数据页总和。SQL Server处理过程中将使用到临时表。
只有一张表有聚集索引的情形类似,SQL Server处理过程中将使用到临时表。并且读入所有的数据页到内存。
如果两张表都有聚集索引,尽管两表的数据都会被读入内存页,但逻辑读数已经大大减少,等于其中一张表总数据内存页数加上最终输出的数据页数。而且SQL Server处理过程中将不需要再使用临时表。
5.2 执行高选择性选取
对于这样的高选择性SQL语句,SQL Server 将提示无法生成执行计划。
以下是引用片段: Select * From P_Order A Inner merge JOIN P_User B ON A.MobileNo=B.MobileNo Where A.MobileNo=28913 |
但可以执行:
以下是引用片段: Select * From P_Order A Inner merge JOIN P_User B ON A.MobileNo=B.MobileNo Where A.MobileNo<=28001 (注:最终结果只有2条) |
这样的属于低选择性语句,但最终结果也很少的语句。如前面所述,这种情况下,采用netsted loop联接效率可能更高。
测试6:执行Hash Join
6.1 执行全表选取或者低选择性选取
执行SQL:
以下是引用片段: Select * From P_Order A Inner hash JOIN P_User B ON A.MobileNo=B.MobileNo |
6.2 执行高选择性选取
和merge join执行高选择性选取情况类似,也无法直接执行:
以下是引用片段: Select * From P_Order A Inner merge JOIN P_User B ON A.MobileNo=B.MobileNo Where A.MobileNo=28913 |
但可以执行这样的结果很少的低选择性脚本:
以下是引用片段: Select * From P_Order A Inner merge JOIN P_User B ON A.MobileNo=B.MobileNo Where A.MobileNo<=28001 (注:最终结果只有2条) |
但此情况下,采用netsted loop联接效率更高。
测试总结
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者