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%'

  • 相关阅读:
    range用法(倒序取值)
    set操作
    map集合 可变对象
    元组
    list操作
    列表推导式、字典推导式、集合推导式
    调用父类方法
    谷歌浏览器真机调试的方法
    css3 flex弹性盒自动铺满写法
    微信小程序保存海报的方法
  • 原文地址:https://www.cnblogs.com/zhanhengzong/p/10137693.html
Copyright © 2011-2022 走看看