嵌套循环连接(Nested Loops), 合并联接(Merge), 哈希联接(Hash)的适用情况
来源:互联网 发布:mysql安装步骤 编辑:程序博客网 时间:2024/05/20 13:38
1.嵌套循环连接(Nested Loops)适用范围
两个表, 一个叫外部表, 一个叫内部表.
如果外部输入非常小,而内部输入非常大并且已预先建立索引,那么嵌套循环联接将特别有效率。
关于连接时哪个表为outer表,哪个为inner表,我发现sql server会自动给你安排,和你写的位置无关,它自动选择数据量小的表为outer表, 数据量大的表为inner表。
2.合并联接(Merge)
指两个表在on的过滤条件上都有索引, 都是有序的, 这样, join时, sql server就会使用Merge join, 这样性能更好.
如果一个有索引,一个没索引,则会选择Nested Loops join.
3.哈希联接(Hash)
如果两个表在on的过滤条件上都没有索引, 则就会使用Hash join.
也就是说, 使用Hash join算法是由于缺少现成的索引.
参考资料:
Inside SQL server 2008 T-SQL.
高级查询优化概念
http://msdn.microsoft.com/zh-cn/library/ms191426(v=SQL.100).aspx
作者:BobLiu
邮箱:lzd_ren@hotmail.com
出处:http://www.cnblogs.com/liuzhendong
邮箱:lzd_ren@hotmail.com
出处:http://www.cnblogs.com/liuzhendong
0 0
- 嵌套循环连接(Nested Loops), 合并联接(Merge), 哈希联接(Hash)的适用情况
- 嵌套循环连接(Nested Loops), 合并联接(Merge), 哈希联接(Hash)的适用情况
- 普通表的Join 三种算法(join 一) 嵌套循环Join(Nested Loops Join)、排序合并Join(Sort-Merge Join)和哈希Join(Hash Join)
- 嵌套循环连接(nested loops join)原理
- 嵌套循环连接(nested loops join)原理
- oracle表连接----->嵌套循环(Nested Loops Join)
- oracle表连接----->嵌套循环(Nested Loops Join)
- Nested Loops Join(嵌套连接)
- Nested Loops Join(嵌套连接)
- Nested Loops Join(嵌套连接)
- NESTED LOOPS & HASH JOINS & MERGE JOIN
- MS SQL 查询联接运算系列----嵌套循环联接
- Oracle执行计划中的连接方式nested loops join、sort merge joinn、hash join
- Nested Loops Join、Hash join、Merge Sort Join三大经典表连接浅谈(笔记)
- Nested loops、Hash join、Sort merge join(三种连接类型原理、使用要点)
- 图解Oracle 表连接优化之嵌套循环连接(Nested loops join)
- 联接
- 联接
- ubuntu grub引导
- equinox的框架的类加载器
- 背景图编辑
- JVM调优总结 -Xms -Xmx -Xmn -Xss
- Android 起步之路
- 嵌套循环连接(Nested Loops), 合并联接(Merge), 哈希联接(Hash)的适用情况
- Servlet 的生命周期
- 如何根治安卓卡顿短板 三星这次有办法
- LaunchImage设置失败的可能原因之一
- 两个线程按顺序打印1~10
- iOS项目开发实战——使用UICollectionView实现瀑布流
- 杭电1008-Elevator
- webview实践
- Grunt入门