SQL优化--使用关联查询代替子查询
2016-09-13 00:00
162 查看
测试例子:
子查询:
select a.*,
(select workflowname from workflowbase where id=workflowid) workflowname
from [[zping.com]]] a
where a.operator='402882ed1112669201112a8385892f33'
执行结果:
(360 行受影响)
表 'Worktable'。扫描计数 360,逻辑读取 142334 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 'workflowbase'。扫描计数 1,逻辑读取 1589 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 '[zping.com]'。扫描计数 1,逻辑读取 366 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
关联查询:
select a.*,b.workflowname
from [[zping.com]]] a inner join workflowbase b on a.workflowid=b.id
where operator='402882ed1112669201112a8385892f33'
执行结果:
(360 行受影响)
表 'Worktable'。扫描计数 0,逻辑读取 0 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 'workflowbase'。扫描计数 1,逻辑读取 1589 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 '[zping.com]'。扫描计数 1,逻辑读取 366 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
这里:子查询IO次数:142334 +1589+366=144289
关联查询IO次数:1589 +366 =1922
关联查询是子查询的75倍
总结:
使用子查询和关联查询,一般情况下如果能用关联查询就不用子查询,
子查询:
select a.*,
(select workflowname from workflowbase where id=workflowid) workflowname
from [[zping.com]]] a
where a.operator='402882ed1112669201112a8385892f33'
执行结果:
(360 行受影响)
表 'Worktable'。扫描计数 360,逻辑读取 142334 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 'workflowbase'。扫描计数 1,逻辑读取 1589 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 '[zping.com]'。扫描计数 1,逻辑读取 366 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
关联查询:
select a.*,b.workflowname
from [[zping.com]]] a inner join workflowbase b on a.workflowid=b.id
where operator='402882ed1112669201112a8385892f33'
执行结果:
(360 行受影响)
表 'Worktable'。扫描计数 0,逻辑读取 0 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 'workflowbase'。扫描计数 1,逻辑读取 1589 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
表 '[zping.com]'。扫描计数 1,逻辑读取 366 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
这里:子查询IO次数:142334 +1589+366=144289
关联查询IO次数:1589 +366 =1922
关联查询是子查询的75倍
总结:
使用子查询和关联查询,一般情况下如果能用关联查询就不用子查询,
相关文章推荐
- SQL优化--使用关联查询代替子查询
- SQL优化--使用关联查询代替子查询
- SQL优化--使用 EXISTS 代替 IN 和 关联查询(inner join) (转载)http://www.cnblogs.com/zping/archive/2008/08/05/1260959.html
- SQL优化--使用 EXISTS 代替 IN 和 inner join来选择正确的执行计划
- 数据库SQL优化——使用EXIST代替IN
- SQL优化--使用 EXISTS 代替 IN 和 inner join来选择正确的执行计划
- SQL优化- 数据库SQL优化——使用EXIST代替IN
- mysql5.7官网直译SQL语句优化--使用存在策略来优化子查询
- SQL优化--使用 EXISTS 代替 IN 和 inner join来选择正确的执行计划
- 使用or展开进行sql优化(即sql语法union all代替or可以提高效率)
- 数据库SQL优化——使用EXIST代替IN
- SQL优化--使用内连接(inner join)代替外连接(left join,right join) (转)
- SQL优化--使用内连接(inner join)代替外连接(left join,right join) (转)
- 数据库SQL优化——使用EXIST代替IN
- MySQL优化之使用连接(join)代替子查询
- 数据库SQL优化——使用EXIST代替IN
- SQL优化--使用内连接(inner join)代替外连接(left join,right join) (转)
- SQL优化--使用内连接(inner join)代替外连接(left join,right join)
- SQL优化--使用 EXISTS 代替 IN 和 inner join来选择正确的执行计划
- SQL优化--使用 EXISTS 代替 IN 和 inner join来选择正确的执行计划