关键字:sql
在两个表都有聚集索引情况下,逻辑读最小,每个表只有2到3次。而且只有实际需要输出的数据才会被读入内存页。两个表都有非聚集索引情况下,消耗的逻辑读和内存资源近似。
测试5:执行Merge Join
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 |
但可以执行:
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/