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

news/2024/7/3 5:17:01


本文接上文:SQL Server 运行计划操作符具体解释(1)——断言(Assert)


前言:


依据计划。本文開始讲述另外一个操作符串联(Concatenation)。读者能够依据这个词(中英文均可)先幻想一下是干嘛的。事实上还是挺直观,就是把东西连起来。那么以下我们来看看究竟连什么?怎么连?什么时候连?

简单介绍:


串联操作符既是物理操作符,也是逻辑操作符。在中文版SQL Server的图形化运行计划中称为“串联”,在其它格式及英文版本号中称为“Concatenation”。

其图标为:Concatenation 运算符图标。它扫描多个输入并返回每一个扫描的行。

通经常使用于实现T-SQL中的UNION ALL。它能够有多个输入,但仅仅有一个输出,就如多个集合UNION ALL一样,终于返回一个结果集,注意这里一直使用“集合/集”,关系数据库是基于集合论的。所以使用关系数据库时要以集合的思维去考虑问题。

在运行计划中的每一个操作符。都要实现三个方法/函数:Init()、GetNext()和Close()。

前面说了,串联操作符是当中一种能够接受多个输入的操作符,这些输入会在Init()方法中处理。

在Init()方法中,串联初始化然后建立所需的数据结构。然后在运行GetNext()方法读取输入集中的第一行及兴许行。直到把输入集合里面的全部数据读取完成为止。


环境搭建:


以下创建一个測试表并循环插入10000行数据。

USE tempdb
GOIF OBJECT_ID('TEST', 'U') IS NOT NULLDROP TABLE TEST
GOCREATE TABLE Test (ID INT Identity(1, 1) PRIMARY KEY,Nome VARCHAR(250) DEFAULT NewID())
GOSET NOCOUNT ON
GOINSERT INTO Test DEFAULT
VALUES 
GO 10000


串联演示:


前面提到,串联主要用于实现T-SQL的UNION ALL ,那么如今就来看看UNION ALL的情况:

开启实际运行计划并运行以下语句:
SELECT * FROM TEST
UNION ALL
SELECT * FROM TEST
UNION ALL
SELECT * FROM TEST
UNION ALL
SELECT * FROM TEST

运行计划例如以下:



假设使用SET SHOWPLAN_TEXT ON来查看的话能够看到例如以下结果:



这个图的含义是把4个“Clustered Index Scan”的结果塞到一个结果集,然后调用Init()和GetNext()方法去遍历这些数据,然后输出。另外须要说明的是这个操作符是依据T-SQL中结果集的出现顺序来处理的,为了证明这个想法,我们来改写一下语句:

SET SHOWPLAN_TEXT ON 
GO
SELECT * FROM TEST
WHERE ID<100
UNION ALL
SELECT * FROM TEST
WHERE ID BETWEEN 101 AND 1000
UNION ALL
SELECT * FROM TEST
WHERE ID BETWEEN 1001 AND 5000
UNION ALL
SELECT * FROM TEST
WHERE ID >5001

然后看看输出:



对照一下參数可得每一个Clustered Index Seek的顺序和语句的出现顺序是一致的。另外读者可能留意到每行最后的ORDERED FORWARD,其含义是扫描索引的顺序是依照聚集索引的顺序并向前扫描。
关于这个话题能够看看SQL Server技术内幕主要作者Kalen Delaney的博客:Ordered Seeks and Scans。

总结:

本文主要演示了串联操作符的情况,而且主要以T-SQL中的UNION ALL来触发。由于眼下没有不论什么资料显示是否仅UNION ALL才会使用,所以这里也不做绝对的推断,读者仅仅须要知道这个操作符的含义、常见情景就可以。另外读者能够使用UNION 来检查运行计划。实际上UNION 是不用串联的,由于它本质上须要去重。所以使用不同的操作符来实现。比方Merge Join,在兴许再介绍。
下一篇将介绍:计算标量:Compute Scalar  

http://lihuaxi.xjx100.cn/news/241719.html

相关文章

UI培训分享:如何成为一名优秀的UI设计师

UI设计师在工作岗位中也是分等级的&#xff0c;如何成为一名优秀的UI设计师在如今的职业发展中是非常有必要的&#xff0c;各行各业都在内卷中&#xff0c;那么如何成为一名优秀的UI设计师呢?来看看下面的详细介绍。 UI培训分享&#xff1a;如何成为一名优秀的UI设计师? 好UI…

2017.1.9版给信息源新增:max_len、max_db字段

2017.1.8a版程序给信息源增加max_len、max_db字段&#xff0c;分别用于控制&#xff1a;获取条数、数据库保留条数。 max_len的说明见此图&#xff1a; max_db的说明见此图&#xff1a; 当max_len和max_db的设置不合理时&#xff08;比如max_len大于max_db&#xff0c;会导致反…

(C++)设计一个程序能计算一个日期加上若干天后是什么日期and计算日期差值

输入第一行表示样例个数m&#xff0c;接下来m行每行四个整数分别表示年月日和累加的天数。 输出m行&#xff0c;每行按yyyy-mm-dd的个数输出。 #include<cstdio>//判断是否是闰年 bool isLeap(int year){return (year%40&&year%100!0)||year%4000; }//用二维数…

删除字符串中出现次数最少的字符

在公交车上看一博客实现删除字符串中出现次数最少的字符&#xff0c;认为里面使用数组来作为hash很好&#xff0c;所以我就自己实现一遍。要求&#xff1a;实现删除一个字符串中出现次数最少的字符。输出删除后的字符&#xff0c;要求安装原来顺序输出。假设出现次数一样&#…

软件测试培训分享:软件测试的职业发展方向有哪些

很多人都觉得软件测试在互联网行业入门是比较轻松的&#xff0c;对于如此轻松的行业&#xff0c;它所在的职业发展前景怎么样呢?软件测试的职业发展方向有哪些呢?本期软件测试培训分享内容请看以下详细介绍。 软件测试的职业发展方向有哪些?职业的选择对于现在的年轻人来说相…

(C++)CSP202006-2 稀疏向量 two pointers

#include<cstdio>const int M 500000;//a,b<5*10^5 int u[M1][2];//第一维是index,第二维是value int v[M1][2];int main(){//1.读入n,a,b//2.对数组进行遍历&#xff0c;如果第一位相等&#xff0c;将第二维相乘 int n,a,b,i;long long ans0;scanf("%d%d%d&qu…

C# GUID的使用

GUID&#xff08;全局统一标识符&#xff09;是指在一台机器上生成的数字&#xff0c;它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成GUID的API。生成算法很有意思&#xff0c;用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。GUID的唯一缺陷在于生…

github上fork了别人的项目后,再同步更新别人的提交

我从github网站和用Git命令两种方式说一下。 github网站上操作 打开自己的仓库&#xff0c;进入code下面。点击new pull request创建。 选择base fork选择head fork点击Create pull request&#xff0c;并填写创建信息。6. 点击Merge pull request 合并从源fork来的代码。 7. 完…