SQL Server查询计划操作符(7.3)——查询计划相关操作符(11)
7.3. 查询计划相关操作符
98)Table Scan:该操作符从查询计划参数列确定的表中获取所有数据行。如果其参数列中出现WHERE:()谓词,则只返回满足该谓词的数据行。该操作符为逻辑操作符和物理操作符。该操作符具体如图7.3-98节点1所示。
![]()
图 7.3-98查询计划操作符Table Scan示例
99)Table Spool:该操作符对其输入进行扫描,并将每个数据行的拷贝放于一个隐藏的假脱机表中,该假脱机表存储于临时数据库且其仅存在于该查询的生命周期。如果该操作符被重绕(例如:通过一个Nested Loops操作符)但无需重新绑定,假脱机数据被使用而非重新扫描其输入。该操作符为物理操作符。该操作符具体如图7.3-99中节点4所示。

图 7.3-99查询计划操作符Table Spool示例
100)Table Update:该操作符对查询计划参数列确定的表中的输入数据行进行更改。其参数列中SET:()谓词决定每个被更改字段所被赋予的值。这些值也许被该操作符的SET子句或该操作符的其他地方或该查询的其他地方参考。该操作符为物理操作符。该操作符具体如图7.3-100中节点1所示。

图 7.3-100查询计划操作符Table Update示例
101)Table-valued Function:该操作符评估一个表值函数(T-SQL或CLR),并将结果数据行存储于临时数据库中。当父操作符请求这些数据行时,该操作符从临时数据库中返回这些数据行。
调用表值函数的查询产生带有该操作符的查询计划。该操作符能被以不同参数值进行评估:
- Table-valued Function XML Reader 输入一个XML BLOB作为参数并产生一个表示按XML文档顺序的XML节点的数据行集。其他输入参数也许会将XML节点限定返回到XML文档的某个子集。
- Table Valued Function XML Reader with XPath filter是一个特殊类型的XML Reader表值函数,其将输出限定到满足某个XPath表达式的XML节点。
该操作符为逻辑操作符和物理操作符。该操作符具体如图7.3-101所示。

图 7.3-101查询计划操作符Table-valued Function示例
102)Top:该操作符扫描其输入,只返回最前面确定数目或确定百分比的数据行,期间,可能会基于某个排序顺序。其参数列可能包含一系列正被用于关系检查的字段。在更改相关的查询计划中,该操作符用于强制行数限定。该操作符为逻辑操作符和物理操作符。该操作符具体如图7.3-102所示。

图 7.3-102查询计划操作符Top示例
103)Top N Sort:该操作符与Sort操作符类似,除了该操作符只需要前N行数据,而非整个结果集。当N值较小时,SQL Server查询执行器试图在内存中执行整个排序操作。当N值很大时,查询执行器将诉诸于更多没有参数N时的通用排序方法。该操作符具体如图7.3-103所示。

图 7.3-103查询计划操作符Top N Sort示例
104)UDX:该操作符(扩展操作符,Extended Operators(UDX))实现SQL Server中众多XQuery及XPath操作中的某个操作。所有该类操作符都是逻辑操作符和物理操作符。
- Extended operator (UDX) FOR XML操作符用于将其输入到单个输出数据行的单个BLOB字段的XML表示中的关系数据行集串行化。该操作符为顺序敏感的XML聚合操作符。
- Extended operator (UDX) XML SERIALIZER操作符按照XML文档顺序输入表示XML节点或XQuery标量的数据行,并在单个输出行的单个XML字段中产生一个串行XML BLOB。该操作符为一个顺序敏感的XML聚合操作符。
- Extended operator (UDX) XML FRAGMENT SERIALIZER操作符为一个特殊类型的XML SERIALIZER ,其被用于处理表示XQuery插入数据修改扩展中正被插入的表示XML片段的输入数据行。
- Extended operator (UDX) XQUERY STRING操作符用于评估表示XML节点的输入数据行的XQuery字符串值。其输出带有一些字段的数据行,这些字段表示包含其输入字符串值的XQuery标量。该操作符为顺序敏感的字符串聚合操作符。
- Extended operator(UDX) XQUERY LIST DECOMPOSER操作符为一个XQuery列表分解操作符。对每个表示XML节点的输入数据行,该操作符将产生一个或多个数据行,如果其输入为XSD列表类型,则这些数据行表示包含一列元素值的XQuery标量。
- Extended operator (UDX) XQUERY DATA操作符对表示XML节点的其输入上的XQuery fn:data()函数进行评估。其输出带有一些字段的一个数据行,这些字段表示包含fn:data()结果的XQuery标量。其为一个顺序敏感的字符串聚合操作符。
- Extended operator XQUERY CONTAINS操作符对表示XML节点的输入上的XQuery fn:contains()函数进行评估。其输出带有一些字段的一个数据行,这些字段表示包含fn:contains()结果的XQuery标量。其为顺序敏感的字符串聚合操作符。
- Extended operator UPDATE XML NODE操作符对XML类型上modify()方法中XQuery替换数据修改扩展中的XML节点进行修改。
105)Union:该操作符对其多个输入进行扫描,输出被扫描的每行数据并对其去重。该操作符为逻辑操作符。该操作符具体如图7.3-105中节点2所示。

图 7.3-105查询计划操作符Union示例
106)Update:该操作符对查询计划参数列确定对象中其输入的每个数据行进行更改。该操作符为逻辑操作符。其物理操作符为Table Update,Index Update或Clustered Index Update。该操作符具体如图7.3-106中节点1所示。

图 7.3-106查询计划操作符Update示例
107)While:该操作符实现T-SQL中的while loop。该操作符为一个语言元素。该操作符具体如图7.3-107所示。

图 7.3-107查询计划操作符While示例
108)Window Spool:该操作符将一行数据展开为代表与其相关窗口的数据集合。一个查询中,OVER子句定义查询结果集中的窗口,一个窗口函数为窗口中的每行数据计算一个值。该操作符为逻辑操作符和物理操作符。该操作符具体如图7.3-108中节点3所示。

图 7.3-108查询计划操作符Window Spool示例
相关文章:
SQL Server查询计划操作符(7.3)——查询计划相关操作符(11)
7.3. 查询计划相关操作符 98)Table Scan:该操作符从查询计划参数列确定的表中获取所有数据行。如果其参数列中出现WHERE:()谓词,则只返回满足该谓词的数据行。该操作符为逻辑操作符和物理操作符。该操作符具体如图7.3-98节点1所示。 图 7.3-…...
xy轴不等比缩放问题——AUTOCAD c#二次开发
在 AutoCAD .net api里,部分实体,像文字、属性、插入块等,是不支持非等比缩放的。 如需对AutoCAD中图形进行xyz方向不等比缩放,则需进行额外的函数封装。 选择图元,指定缩放基准点,scaleX 0.5, scaleY …...
【原创首发】开源基于AT32 SIP/VOIP电话
前言 本次为了反馈各位粉丝的关注,特此分享 AT32_VOIP 工程,此功能其实跟我之前发过的《STM32F429的VOIP功能》是一样的,只是用了AT32F437。 其实那个工程是一个比较Demo中的Demo,很多功能和硬件依赖性太大了。后面项目中发现AT…...
本地部署 LangManus
本地部署 LangManus 0. 引言1. 部署 LangManus2. 部署 LangManus Web UI 0. 引言 LangManus 是一个社区驱动的 AI 自动化框架,它建立在开源社区的卓越工作基础之上。我们的目标是将语言模型与专业工具(如网络搜索、爬虫和 Python 代码执行)相…...
一篇文章入门Python Flask框架前后端数据库开发实践(pycharm在anaconda环境下)
Python Flask 是一个轻量级的 Web 应用框架,也被称为微框架。它以简洁、灵活和易于上手的特点而受到开发者的喜爱。 核心特点 轻量级:Flask 核心代码简洁,仅包含 Web 开发的基本功能,不强制使用特定的数据库、模板引擎等…...
SpringBoot分布式定时任务实战:告别重复执行的烦恼
场景再现:你刚部署完基于SpringBoot的集群服务,凌晨3点突然收到监控告警——优惠券发放量超出预算两倍!检查日志发现,两个节点同时执行了定时任务。这种分布式环境下的定时任务难题,该如何彻底解决? 本文将…...
AI+金融 应用 使用DeepSeek、Qwen等大模型输入自然语言,得到通达信等行情软件公式代码,导入后使用
AI金融 应用 使用DeepSeek、Qwen等大模型输入自然语言,得到通达信等行情软件公式代码,导入后使用。不会编程,也能行情软件中实现个性化条件选股,个性化技术指标。 AIbxm低估值趋势选股策略,参考提示词: 编…...
C++20 中的同步输出流:`std::basic_osyncstream` 深入解析与应用实践
文章目录 一、std::basic_osyncstream 的背景与动机二、std::basic_osyncstream 的基本原理三、std::basic_osyncstream 的使用方法(一)基本用法(二)多线程环境下的使用(三)与文件流的结合 四、std::basic_…...
Android 关于compose的一些坑和理解
** 1.如何在 WindowManager.addView 中使用 Jetpack Compose** 一、引出问题 Android 开发中,很常见的一个场景,通过 WindowManager.addView() 添加一个 View 到屏幕上。Android 最新的视图框架 Jetpack Compose,如何应用进来。这个被添加的…...
LeetCode 30 —— 30.串联所有单词的子串
题目: 给定一个字符串 s 和一些长度相同的单词 words。找出 s 中恰好可以由 words 中所有单词串联形成的子串的起始位置。 注意子串要与 words 中的单词完全匹配,中间不能有其他字符,但不需要考虑 words 中单词串联的顺序。 示例 1ÿ…...
go语言中的strings库
strings库 func EqualFold func EqualFold(s, t string) bool判断两个utf-8编码字符串(将unicode大写、小写、标题三种格式字符视为相同)是否相同。 func main() {fmt.Println(strings.EqualFold("hello", "hello")) //truefmt.…...
【嵌入式硬件】三款DCDC调试笔记
关于开关电源芯片,重点关注输入电源范围、输出电流、最低压降。 1.MP9943: 以MP9943为例,输入电压范围4-36V,输出最大电流3A,最低压降为0.3V 调整FB使正常输出为5.06V 给定6V空载、5V空载、5V带2A负载的情况: 6V带2A…...
Cannot find module @rollup/rollup-win32-x64-msvc
方法1 在package.json中添加postinstall: "scripts": {"postinstall": "node -e \"const { platform } process; if (platform win32) { require(child_process).execSync(npm install rollup/rollup-win32-x64-msvc, { stdio: inherit });…...
Linux中修改文件的权限用什么命令?
一、核心语法 chmod [选项] [权限模式] 文件名二、权限模式详解 1. 数字模式(推荐使用) 通过rwx权限对应的数值组合: r(读)→ 4w(写)→ 2x(执行)→ 1无权限 → 0 组合规…...
【FPGA开发】FPGA点亮LED灯(增加按键暂停恢复/复位操作)
目录 一、VScode下载安装 1.1 官网下载 1.2 安装插件 二、LED流水灯点亮 2.1 任务说明 2.2 新建项目 2.3 创建Verilog文件添加至顶层实体 2.4 引脚分配 2.5 选择烧录器 2.6 添加烧录文件&下载 2.7 烧录结果 三、增加按键操作 3.1 按键暂停和恢复功能&…...
companion object和object 从kotlin转java分析
说明 companion object 中 companion类中的方法是普通的方法 在外部类中生成静态变量,静态companion 对象 object MyClass2 中 类中方法是普通方法 在MyClass2中生成静态变量,静态MyClass2对象, 一 companion object 使用 kotlin转java pa…...
Spring MVC 执行流程:一个请求在 Spring MVC 中是如何执行的?
当用户发送一个 HTTP 向 Spring MVC 应用,该请求在 Spring MVC 的执行流程如下: 当用户向 Spring MVC 发起一个 HTTP 请求,该请求会被 Dispatcher Servlet(前端控制器)拦截;DispatcherServlet 调用 Handler…...
三主热备架构
1.要求 角色主机名软件IP地址用户client192.168.72.90keepalivedvip192.168.72.100masterserverAkeepalived, nginx192.168.72.30backupserverBkeepalived, nginx192.168.72.31backupserverCkeepalived, nginx192.168.72.32webtomcat1tomcat192.168.72.41webtomcat2tomcat192.1…...
HTML 表单处理进阶:验证与提交机制的学习心得与进度(二)
步步为营:表单提交机制全面解析 提交方式详解 GET 与 POST 对比 在 HTML 表单提交中,GET 和 POST 是最为常用的两种提交方式,它们在诸多方面存在显著差异。 安全性:GET 方式将表单数据附加在 URL 的查询字符串中,数…...
JavaScript | 爬虫逆向 | 语法基础| 01
一、摘要 实践是最好的导师 二、环境配置 在开始之前,需要确保你的计算机上已经安装了 Node.js。Node.js 是一个开源的、跨平台的 JavaScript 运行时环境,它允许你在服务器端运行 JavaScript 代码。 1. 下载 安装地址:https://nodejs.org…...
python解决多个矢量点图层合并为一个点图层
1、解决矢量点图层的合并 2、解决多个点图层分别合并为不同图层(一个文件夹下所有点图层合并为一个图层,以下代码为两个文件夹,分别合并为两个总的图层) import geopandas as gpd import os import pandas as pddef merge_shapef…...
VL开源模型实现文本生成图片
一、 基础知识 根据描述生成图片的视觉-语言模型(Vision-Language Models, VL 模型)是近年来多模态生成领域的热点研究方向。这些模型能够根据自然语言描述生成高质量的图像,广泛应用于艺术创作、设计辅助、虚拟场景构建等领域。 1 根据描述…...
字节跳动实习生主导开发强化学习算法,助力大语言模型性能突破
目录 禹棋赢的背景与成就 主要成就 DAPO算法的技术细节 算法优势 禹棋赢的研究历程 关键时间节点 字节跳动的“Top Seed人才计划” 计划特点 小编总结 在大模型时代,经验不再是唯一的衡量标准,好奇心、执行力和对新技术的敏锐洞察力成为推动技术…...
九、JavaScript作用域、预解析
一、JavaScript作用域 1.JavaScript作用域 ①代码名字(变量)在某个范围内起作用和效果 目的是为了提高程序的可靠性更重要的是减少命名冲突 ②js的作用域(es6)之前:全局作用域 局部作用域 ③全局作用域:整…...
前后端+数据库的项目实战:hbu迎新网-较复杂(下)javaweb
目录 十一、实现对内容的富文本编辑(换行、图片颜色等等样式) (1)下载富文本编辑器,引入资源 (2)将原项目的内容部分替换为富文本编辑器 1、替换添加页面 2、替换修改页面(和添…...
Java-模块二-2
整数类型 byte:在 Java 中占用8位(1字节),因此它的取值范围是从 -128 到 127。这是最小的整数类型,适合用于节省空间的情况。 short:这种类型的大小是16位(2字节),允许的…...
Redis、Memcached应用场景对比
环境 Redis官方网站: Redis - The Real-time Data Platform Redis社区版本下载地址:Install Redis | Docs Memcached官方网站:memcached - a distributed memory object caching system Memcached下载地址:memcached - a dis…...
【单片机通信技术应用——学习笔记三】液晶屏显示技术,取模软件的应用
一、液晶显示技术简介 1.RGB信号线 RGB是一种色彩模式,是工业界的一种颜色标准,是通过红(R)、绿(G)、蓝(B)三个颜色通道的变化,以及它们相互之间的叠加来得到各式各样的…...
MySQL颠覆版系列————MySQL新特性(开启数据库的新纪元)上篇
文章目录 前言一、窗口函数(Window Functions)1.1 窗口函数概念1.2 常见的窗口函数 二、公用表表达式(Common Table Expressions, CTEs)2.1 公用表表达式的概念2.2 常见的公用表表达式 三、JSON增强3.1 JSON增强的概念3.2 常见的J…...
MySQL 调优:查询慢除了索引还能因为什么?
文章目录 情况一:连接数过小情况二:Buffer Pool 太小 MySQL 查询慢除了索引还能因为什么?MySQL 查询慢,我们一般也会想到是因为索引,但除了索引还有哪些原因会导致数据库查询变慢呢? 以下以 MySQL 中一条 S…...
