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

  • 相关阅读:
    七牛云上传图片
    找到当前字符串中最后一个/并获取之后的字符串
    jquery正则表达式验证:验证身份证号码
    apply()与call()的区别
    js 判断字符串是否包含某字符串,String对象中查找子字符,indexOf
    改变父元素的透明度,不影响子元素的透明度—css
    c实现生产者消费者问题。 windows下。
    python基础练习 dict切片
    html+css test1
    codewars[7]-python Friend or Foe?
  • 原文地址:https://www.cnblogs.com/zhanhengzong/p/10137693.html
Copyright © 2011-2022 走看看