常见的操作符:Sort、Hash Match(聚合)、Filter、Compute Scalar等

一:Sort

select Shelf from  Production.ProductInventory order by Shelf

  

在进行聚集索引扫描操作后,数据集进行了Sort操作。当优化器认为在执行过程中需要对数据尽心排序时,就会产生这个操作。

整个查询对1069行数据进行了排序操作。排序操作本身不是问题,问题是他的开销已经达到了76%。因为没有索引存在。只能执行Sort操作,这个列子是缺少了where条件,返回了非预期的数据;也可能因为缺少具有排序功能的索引,使用聚集索引可以实现预排序功能,从而减少了排序开销。

可以Order By一个聚集索引来消除Sort操作。

select * from Production.ProductInventory order by ProductID

  

加入了Order By子句,但是执行计划并没有出现Sort操作符,因为这个聚集索引以及你按顺序存储了数据,优化器会认为没有必要再次排序。如果必须排序,Sql Server会优先选择在内存中进行,如果排序的数据集实在太大,SQL Server就只能把数据放在TempDB中并在磁盘中排序。这时候会触发Sort Warning事件。

2.Hash Match(聚合)

在查询中需要进行聚合操作(COUNT/SUM/AVG/MAX/MIN)有时就可能出现这种操作符

select City,COUNT(City) as CityCount from Person.Address group by City

  

该语句没有 Where 条件,所以使用Index Scan来返回全部的数据,然后优化器使用聚集索引来实现COUNT的逻辑。由于数据量比较大,所以优化器会选择Hash Match聚合操作符。首先在内存中创建临时哈希表,然后计算满足GROUP BY条件的数据,最终汇总数据并返回

聚合操作是昂贵的操作,可能只有通过添加有效的WHERE条件或者通过使用索引视图预先聚合的方式来提高性能。

3.Filter

select City,COUNT(City) as CityCount from Person.Address group by city having COUNT(City)>1

  

当引入HAVING子句后,就出现了Filter操作符,这个操作符会对输出再次进行限制,可以对比Filter前后的数据量

如图:

要注意:看上去HAVING子句减少了数据量,但是实际并没有,因为HAVING子句只会在聚合操作完成后才进行,而常见的性能问题都在聚合操作之前,所以除了添加WHERE条件控制聚合的数据量之外,这种可操作符没有什么可提升空间

4.Compute Scalar  --计算标量

这个操作符主要用于标量操作,通常出现在SELECT过程中,需要重新组合数据列

select e.JobTitle,
a.City,
p.LastName+', '+p.FirstName as EmployeeName
from HumanResources.Employee as e
join Person.BusinessEntityAddress as bea on e.BusinessEntityID=bea.BusinessEntityID
join Person.Address a on bea.AddressID=a.AddressID
join Person.Person as p on e.BusinessEntityID=p.BusinessEntityID

  

在这个查询中LastName和FirstName合并成了一个新列EmployeeName,这种操作符没有什么问题,但是如果在WHERE、JOIN的ON条件中出现,那可能表示存在问题,需要考虑使用计算列等方式来改进

SQL Server常见的操作符的更多相关文章

  1. SQL Server 执行计划操作符详解(3)——计算标量(Compute Scalar)

    接上文:SQL Server 执行计划操作符详解(2)--串联(Concatenation ) 前言: 前面两篇文章介绍了关于串联(Concatenation)和断言(Assert)操作符,本文介绍第 ...

  2. SQL Server 执行计划操作符详解(2)——串联(Concatenation )

    本文接上文:SQL Server 执行计划操作符详解(1)--断言(Assert) 前言: 根据计划,本文开始讲述另外一个操作符串联(Concatenation),读者可以根据这个词(中英文均可)先幻 ...

  3. SQL Server 运行计划操作符具体解释(2)——串联(Concatenation )

    本文接上文:SQL Server 运行计划操作符具体解释(1)--断言(Assert) 前言: 依据计划.本文開始讲述另外一个操作符串联(Concatenation).读者能够依据这个词(中英文均可) ...

  4. SQL Server 运行计划操作符具体解释(3)——计算标量(Compute Scalar)

    接上文:SQL Server 运行计划操作符详细解释(2)--串联(Concatenation ) 前言: 前面两篇文章介绍了关于串联(Concatenation)和断言(Assert)操作符,本文介 ...

  5. SQL Server常见数据类型介绍

    数据表是由多个列组成,创建表时必须明确每个列的数据类型,以下列举SQL Server常见数据类型的使用规则,方便查阅. 1.整数类型 int 存储范围是-2,147,483,648到2,147,483 ...

  6. SQL Server 常见数据类型介绍

    数据表是由多个列组成,创建表时必须明确每个列的数据类型,以下列举SQL Server常见数据类型的使用规则,方便查阅. 整数类型 int 存储范围是-2,147,483,648到2,147,483,6 ...

  7. SQL SERVER常见等待——解决会话等待产生的系统问题

    SQL SERVER——解决会话等待产生的系统问题 转自: https://blog.csdn.net/z_cloud_for_SQL/article/details/55051215 版权声明:SQ ...

  8. SQL Server 执行计划操作符详解(1)——断言(Assert)

    前言: 很多很多地方对于语句的优化,一般比较靠谱的回复即使--把执行计划发出来看看.当然那些只看语句就说如何如何改代码,我一直都是拒绝的,因为这种算是纯蒙.根据本人经验,大量的性能问题单纯从语句来看很 ...

  9. SQL Server 运行计划操作符具体解释(1)——断言(Assert)

    前言: 非常多非常多地方对于语句的优化,一般比較靠谱的回复即使--把运行计划发出来看看.当然那些仅仅看语句就说怎样怎样改代码,我一直都是拒绝的,由于这样的算是纯蒙.依据本人经验,大量的性能问题单纯从语 ...

随机推荐

  1. [转]python3之日期和时间

    转自:https://www.cnblogs.com/zhangxinqi/p/7687862.html#_label6 阅读目录 1.python3日期和时间 2.时间元组 3.获取格式化的时间 4 ...

  2. 【转】MySQL— 索引

    [转]MySQL— 索引 目录 一.索引 二.索引类型 三.索引种类 四.操作索引 五.创建索引的时机 六.命中索引 七.其它注意事项 八.LIMIT分页 九.执行计划 十.慢查询日志 一.索引 My ...

  3. Excel自动建组

    已用于测试用例自动创建组 使用要求:A列的格式如:X.X.X.X.X11.11.1.11.1.1.11.1.1.1.11.1.1.21.1.21.22 会自动将1.1.1.1.1-1.1.1.1.X组 ...

  4. python模块之sniffio

    嗅探python用了哪个异步库 from sniffio import current_async_library import trio import asyncio async def print ...

  5. 【转】JVM内存结构 VS Java内存模型 VS Java对象模型

    JVM内存结构 我们都知道,Java代码是要运行在虚拟机上的,而虚拟机在执行Java程序的过程中会把所管理的内存划分为若干个不同的数据区域,这些区域都有各自的用途. 其中有些区域随着虚拟机进程的启动而 ...

  6. RabbitMQ 选型和对比

    背景 这个纯粹是记下知识点,知道自己在这个时候了解过这个技术.技术点网上很多,就不多说了.只是想起多年前做过的一次项目,是多个项目整合,各种数据库,java和c#项目,互相调来调去,甚至直接链接对方数 ...

  7. 020_nginx禁止ip默认参数是$remote_addr无法禁止真实ip的问题

    由于网站使用了cdn所以$remote_addr获取的ip是cdn的ip,我现在先禁止某些ip访问发现无法禁止cdn传递过来的客户端的ip也就是$http_x_forwarded_for这个参数.比如 ...

  8. 利用表格分页显示数据的js组件datatable的使用

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. PHP一维数组转二维数组正则表达式

    2017年11月20日17:17:08 array(1 => '哈哈')  变成  array('id' => 1, 'name' => '哈哈') 查找目标:  (\d)\s=&g ...

  10. Django请求周期图