zoukankan      html  css  js  c++  java
  • SqlServer执行计划

    MSSQLSERVER执行计划详解

    --1、取前10条-性能相同

    select top 10 * from ServiceInvoke; --创建时间聚集索引扫描 select top 10 * from AdoLog; --主键ID聚集索引扫描

    --2、根据聚集索引排序-性能提升
    --创建时间聚集索引扫描,但是时间索引是已排序的,所以不需要再排序
    select top 10 * from ServiceInvoke order by CreateTime desc;
    --主键ID聚集索引全表扫描,然后根据时间字段排序
    select top 10 * from AdoLog order by CreateTime desc;

     

    --3、根据非索引排序-性能相同
    --创建时间聚集索引扫描,然后根据排序字段排序
    select top 10 * from ServiceInvoke order by IsDeleted desc;
    --主键ID聚集索引扫码,然后根据排序字段排序
    select top 10 * from AdoLog order by Message desc;

    --4、根据聚集索引筛选,性能提升
    --创建时间聚集索引查找
    select top 10 * from ServiceInvoke where CreateTime > '2018-12-18';
    --主键ID聚集索引扫描
    select top 10 * from AdoLog where CreateTime > '2018-12-18' ;

    --5、根据聚集索引筛选排序-性能提升
    --创建时间聚集索引查找
    select top 10 * from ServiceInvoke where CreateTime > '2018-12-18' order by CreateTime desc;
    --主键ID聚集索引扫描
    select top 10 * from AdoLog a where CreateTime > '2018-12-18' order by CreateTime desc;

    --6、普通字段筛选聚集索引字段排序-对于排序性能消耗较大的情况下性能提升
    --创建时间聚集索引扫描,然后条件过滤,但是不用排序
    select top 10 * from ServiceInvoke where OutParam like '%330723196704072361%' order by CreateTime desc;
    --主键ID聚集索引扫描,然后排序
    select top 10 * from AdoLog where Message like '%330723196704072361%' order by CreateTime desc;

      

    --7、多字段筛选聚集索引排序-性能提升
    --创建时间聚集索引查找,然后条件过滤,但是不用排序
    select top 10 * from ServiceInvoke where OutParam like '%330723196704072361%' and CreateTime > '2018-12-18' order by CreateTime desc;
    --主键ID聚集索引扫描,然后排序
    select top 10 * from AdoLog a where Message like '%330723196704072361%' and CreateTime > '2018-12-18' order by CreateTime desc;

    --8、多字段搜索普通字段排序-性能提升
    --创建时间聚集索引查找,然后条件过滤,排序
    select top 10 * from ServiceInvoke where OutParam like '%330723196704072361%' and CreateTime > '2018-12-18' order by OutParam desc;
    --主键ID聚集啥事扫描,排序
    select top 10 * from AdoLog a where Message like '%330723196704072361%' and CreateTime > '2018-12-18' order by Message desc;

    --9、统计行数
    --主键非聚集索引扫描 select count(*) from ServiceInvoke
    --主键非聚集索引扫描,但是查找行数明细减少,性能提升
    select count(*) from ServiceInvoke s where s.CreateTime > '2018-12-19'
    --创建时间聚集索引扫描,然后过滤 select count(*) from ServiceInvoke s where s.InputParam like '%152%'
    --创建时间聚集索引查找,然后过滤-性能提升 select count(*) from ServiceInvoke s where s.CreateTime > '2018-12-19' and s.InputParam like '%152%'

     

    --10、使用聚集索引和强制使用非聚集索引-根据聚合索引字段(创建时间)筛选出来的数据越少,查询开销提升越明显
    --创建时间聚合索引查找 select count(*) from ServiceInvoke s where s.CreateTime > '2018-12-19' and s.InputParam like '%152%'
    --主键ID非聚合索引扫描 select count(*) from ServiceInvoke s with(index=[PK_dbo.ServiceInvoke]) where s.CreateTime > '2018-12-19' and s.InputParam like '%152%'

  • 相关阅读:
    源码搭建zabbix平台
    如何用手机远程控制自己的电脑
    nginx无法启动问题详解
    在<script>中加HTML注释标签<!-- --> 的原因?
    UNICODE,GBK,UTF-8区别
    dart学习一 windows环境安装dart环境
    Git使用方法(精心整理,绝对够用)
    非常好用的jQuery表格排序插件
    Redis NOAUTH Authentication required.
    Docker概念、安装
  • 原文地址:https://www.cnblogs.com/zhanhengzong/p/10137693.html
Copyright © 2011-2022 走看看