SQL Server的执行计划(Execution Plans)

news2024/12/23 3:40:17

执行计划

  • 一、背景
  • 二、显示和保存执行计划
  • 三、显示估计的执行计划
  • 四、显示实际执行计划
  • 五、以 XML 格式保存执行计划
  • 六、比较和分析执行计划
    • 6.1、比较执行计划
    • 6.2、分析实际执行计划
  • 总结

一、背景

为了能够执行查询,SQL Server 数据库引擎必须分析该语句,以确定访问所需数据的最有效方法。此分析由称为查询优化器的组件处理。查询优化器的输入由查询、数据库架构(表和索引定义)和数据库统计信息组成。查询优化器的输出是查询执行计划,有时称为查询计划或执行计划。

查询执行计划是以下内容的定义:

  • 访问源表的顺序。通常,数据库服务器可以在许多序列中访问基表以生成结果集。
  • 用于从每个表中提取数据的方法。通常,访问每个表中的数据有不同的方法。如果只需要具有特定键值的几行,则数据库服务器可以使用索引。如果表中的所有行都是必需的,数据库服务器可以忽略索引并执行表扫描。如果表中的所有行都是必需的,但有一个索引的键列位于 中,则执行索引扫描而不是表扫描可能会保存单独的结果集。如果表非常小,则表扫描可能是几乎所有访问表的最有效方法。
  • 用于计算计算的方法,以及如何筛选、聚合和排序每个表中的数据。从表中访问数据时,有不同的方法可以对数据执行计算(例如计算标量值),以及聚合和排序查询文本中定义的数据,以及如何筛选数据。

在这里插入图片描述

二、显示和保存执行计划

执行计划以图形方式显示 SQL Server 查询优化器选择的数据检索方法。执行计划使用图标而不是 SET SHOWPLAN_ALL或 SET SHOWPLAN_TEXT 语句生成的表格表示形式来表示 SQL Server 中特定语句和查询的执行开销。这种图形方法对于了解查询的性能特征非常有用。

虽然 SQL Server 查询优化器只生成一个执行计划,但存在估计执行计划和实际执行计划的概念。

  • 估计的执行计划返回查询优化器在编译时生成的执行计划。生成估计的执行计划不会实际执行查询或批处理,因此不包含任何运行时信息,例如实际资源使用情况指标或运行时警告。
  • 实际执行计划返回查询优化器生成的执行计划,并在查询或批处理完成后返回执行计划。这包括有关资源使用情况指标和任何运行时警告的运行时信息。

三、显示估计的执行计划

生成估计的执行计划时,不会执行 T-SQL 查询或批处理。因此,估计的执行计划不包含任何运行时信息,例如实际资源使用情况指标或运行时警告。相反,生成的执行计划显示 SQL Server 数据库引擎在实际执行查询时最有可能使用的查询执行计划,并显示流经计划中多个运算符的估计行。

若要使用此功能,用户必须具有执行要为其生成图形执行计划的 T-SQL 查询的适当权限,并且必须向他们授予查询引用的所有数据库的 SHOWPLAN 权限。

通过 SSMS、EXPLAIN 和 SET SHOWPLAN_XML的估计执行计划可用于 Azure Synapse Analytics 中的专用 SQL 池(以前称为 SQL DW)和专用 SQL 池。

注意:使用 SET SHOWPLAN_XML返回每个语句的执行计划信息而不执行它。

四、显示实际执行计划

实际执行计划是在执行 T-SQL 查询或批处理后生成的。因此,实际执行计划包含运行时信息,例如实际资源使用指标和运行时警告(如果有)。生成的执行计划显示 SQL Server 数据库引擎用于执行查询的实际查询执行计划。

若要使用此功能,用户必须具有执行正在为其生成图形执行计划的 Transact-SQL 查询的适当权限,并且必须向他们授予查询引用的所有数据库的 SHOWPLAN 权限。

五、以 XML 格式保存执行计划

要执行计划功能或使用 XML 显示计划 SET 选项,用户必须具有执行要为其生成执行计划的 Transact-SQL 查询的适当权限,并且必须向他们授予查询引用的所有数据库的 SHOWPLAN 权限。

使用以下语句打开SHOWPLAN_XML:

SET SHOWPLAN_XML ON;  
GO

若要打开统计信息 XML,请使用以下语句:

SET STATISTICS XML ON;  
GO

执行查询:

USE AdventureWorks2012;  
GO  
SET SHOWPLAN_XML ON;  
GO  
-- Execute a query.  
SELECT BusinessEntityID   
FROM HumanResources.Employee  
WHERE NationalIDNumber = '509647174';  
GO  
SET SHOWPLAN_XML OFF;

六、比较和分析执行计划

执行计划以图形方式显示 SQL Server 查询优化器选择的数据检索方法。执行计划使用图标而不是 SET SHOWPLAN_ALL或 SET SHOWPLAN_TEXT 语句生成的表格表示形式来表示 SQL Server 中特定语句和查询的执行开销。这种图形方法对于理解查询的性能特征非常有用。

SQL Server Management Studio 包含的功能允许用户比较两个执行计划(例如,同一查询的感知好计划和坏计划),并执行根本原因分析。还包括执行单个查询计划分析的功能,允许通过分析查询的执行计划来深入了解可能影响查询性能的方案。

6.1、比较执行计划

出于故障排除原因,数据库专业人员可能必须执行比较计划的功能:

  • 查找查询或批处理突然变慢的原因。
  • 了解查询重写的影响。
  • 观察引入架构设计的特定性能增强更改(如新索引)如何有效地更改执行计划。

可以在以下两者之间进行比较:

  • 两个以前保存的执行计划文件(扩展名为 .sqlplan)。
  • 一个活动的执行计划和一个以前保存的查询执行计划。
  • 查询存储中的两个选定查询计划。

比较两个执行计划时,计划中执行基本相同的区域将以相同的颜色和图案突出显示。单击一个计划中的颜色区域会将另一个计划居中放在该计划中的匹配节点上。仍然可以比较执行计划的不匹配运算符和节点,但在这种情况下,必须手动选择要比较的运算符。

在这里插入图片描述

6.2、分析实际执行计划

查询性能故障排除需要在了解查询处理和执行计划方面具有丰富的专业知识,以便能够实际查找和修复根本原因。

SQL Server Management Studio 包括在实际执行计划分析任务中实现某种程度自动化的功能,尤其是对于大型和复杂的计划。目标是更轻松地查找基数估计不准确的方案,并获取有关可能可用的缓解措施的建议。

总结

  1. 实际执行计划是在事务处理 SQL 查询或批处理执行后生成的。因此,实际执行计划包含运行时信息,例如实际行数、资源使用指标和运行时警告(如果有)。
  2. 只有考虑更改计划形状的节点才会用于检查相似性。因此,在计划同一子部分中的两个节点的中间可能存在一个未着色的节点。在这种情况下,缺少颜色意味着在检查部分是否相等时未考虑节点。
  3. 在将建议的缓解措施应用于生产环境之前,请确保对其进行适当的测试。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/417496.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

21100颗星的Locust性能测试工具到底有多牛!

一句话:用普通的Python编写可扩展的负载测试,就够了,懂得自然懂! Locust是一个易于使用、可编写脚本和可扩展的性能测试工具。你在常规的Python代码中定义你的用户的行为,而不是受制于一个UI或领域特定的语言&#xff…

HTB-Obscurity

HTB-Obscurity信息收集8080端口立足www-data -> robertrobert -> rootsudo 注入hash捕获信息收集 8080端口 ”如果攻击者不知道你在使用什么软件,你就不会被黑客攻击!“,目标对web的指纹做了某些处理。 “‘SuperSecureServer.py’ in the secre…

【从零开始学Skynet】基础篇(六):MySql数据库安装操作

游戏服务端的另一项重要功能是保存玩家数据,Skynet提供了操作MySQL数据库、MongoDB数据库的模块。1、数据库安装 首先安装Mysql服务器,打开终端输入如下指令: sudo apt-get install mysql-server 按下回车,输入密码后开始安装&a…

秒杀架构(二) -- nginx实现限流

限流(Rate Limitting)是服务降级的一种方式,通过限制系统的输入和输出流量以达到保护系统的目的。比如我们的网站暴露在公网环境中,除了用户的正常访问,网络爬虫、恶意攻击或者大促等突发流量都可能都会对系统造成压力…

OpenCV按指定大小分割图像并保存详细讲解

这几天在忙着整理自己的数据集,使用工业级相机拍了好多高清照片,但是模型训练的时候需要使用512*512像素点大小的图像,而且我的模型设计的时候就已经规定好了训练样本大小。 那就分割呗,把拍的照片按512*512分割一小块一小块的&am…

easyx

普通的画线图什么的 首先我们需要安装一个easyx的图形库&#xff0c;然后把头文件搞出来 #include <stdio.h> #include <easyx.h>//easyx画线啥啥的图形库 #include <graphics.h> #include <math.h> #include <conio.h>//键盘操作的头文件 设…

2023年mathorcupD题航空安全风险分析和飞行技术评估思路分析

2023年mathorcupD题航空安全风险分析和飞行技术评估思路分析 飞行安全是民航运输业赖以生存和发展的基础。随着我国民航业的快 速发展&#xff0c;针对飞行安全问题的研究显得越来越重要。2022 年 3 月 21 日&#xff0c;“3.21” 空难的发生终结了中国民航安全飞行 1 亿零 59…

Android中级——性能优化

性能优化布局优化UI渲染机制避免Overdraw优化布局层级利用<include\>重用Layout使用<ViewStub\>实现View的延迟加载Hierarchy View内存优化获取内存信息ProfilerTraceViewMAT&#xff08;Memory Analyzer Tool&#xff09;dumpsys布局优化 UI渲染机制 画面流畅需…

透过Gartner最新报告,认识“超级边缘”

当下&#xff0c;酝酿能量的超级边缘。最近&#xff0c;我们在谈视频化狂飙、谈AIGC颠覆、谈算力动能不足&#xff0c;很少谈及边缘。但“边缘”恰恰与这一切相关&#xff0c;且越发密不可分&#xff0c;它是未来技术发展的极大影响因子。 “到2025年&#xff0c;超过70%的组织…

Segment Anything Model

论文翻译&#xff1a; 图1&#xff1a;我们旨在通过引入三个相互关联的组件来构建分割的基础模型&#xff1a;即时分割任务、支持数据注释并通过即时工程将零样本传输到一系列任务的分割模型&#xff08;SAM&#xff09;&#xff0c;以及用于收集SA-1B的数据引擎&#xff0c;SA…

MappingGenerator PRO 2023.3 Visual Studio 2019-2022

您的私人编码助手 MappingGenerator 最初是作为 AutoMapper 的设计时替代品创建的。现在它正在演变为编码助手&#xff0c;您可以将最平凡的编码任务委派给它&#xff1a; 生成映射生成显式转换实施克隆生成投影表达式脚手架方法调用脚手架对象创建清理方法调用方便ILogger的使…

探讨Hive是否转为MapReduce程序

目录 前提条件 数据准备 探讨HQL是否转为MapReduce程序执行 1.设置hive.fetch.task.conversionnone 2.设置hive.fetch.task.conversionminimal 3.设置hive.fetch.task.conversionmore 前提条件 Linux环境下安装好Hive&#xff0c;这里测试使用版本为&#xff1a;Hive2.3.…

【结构型模式】适配者模式

文章目录优秀借鉴1、简介2、结构3、实现方式3.1、案例引入3.2、类适配器3.3、对象适配器3.4、接口适配器4、区别对比5、适配者模式优缺点6、应用场景优秀借鉴 黑马程序员Java设计模式详解-适配器模式概述适配器设计模式&#xff08;封装器模式&#xff09;一文彻底弄懂适配器模…

页眉怎么添加【节】,设置不同章节不同页眉

文章目录前言添加【节】&#xff0c;设置不同内容总结前言 大家写文档或者论文的时候可能会需要&#xff1a;不同章节页眉展示不同的内容 然而&#xff0c;在双击页眉进行编辑的时候却发现几个章节的页眉一起被修改了&#xff1a; 会出现文章与页眉不同步的情况&#xff0c…

idea使用Junit

文章目录 idea使用JunitJunit配置常用注解常用于测试的断言方法后续idea使用Junit 对项目使用Junit主要有两个步骤: 添加Junit依赖,即添加Junit jar包使用JunitJunit配置 方法一:idea自带的快捷方法 对要测试的类的方法,在该类中,右键鼠标呼出菜单,选择Generate,快捷…

简单的回顾Linux

linux命令ls会显示出文件的颜色, 系统约定的默认颜色含义如下: 白色&#xff1a;表示普通文件 蓝色&#xff1a;表示目录 绿色&#xff1a;表示可执行文件 红色&#xff1a;表示压缩文件 浅蓝色&#xff1a;链接文件 主要是使用ln命令建立的文件 红色闪烁&#xff1a;表示链接的…

Java实现打印杨辉三角形,向左、右偏的平行四边形这三个图形代码程序

目录 前言 一、打印杨辉三角形 1.1运行流程&#xff08;思想&#xff09; 1.2代码段 1.3运行截图 二、向左偏的平行四边形 1.1运行流程&#xff08;思想&#xff09; 1.2代码段 1.3运行截图 三、向右偏的平行四边形 1.1运行流程&#xff08;思想&#xff09; 1.2代…

inplace-operation-error 【已解决】

最近在搞CT医学图像分割模型的领域泛化优化&#xff0c;结果就出现了报错&#xff1a; 关于这个问题stackoverflow上有非常多的讨论&#xff0c;可以过去围观&#xff1a; 指路&#xff1a;中文版stackoverflow - 堆栈内存溢出 (stackoom.com) Stack Overflow - Where Develo…

UNET-RKNN分割眼底血管

前言 最近找到一个比较好玩的Unet分割项目&#xff0c;Unet的出现就是为了在医学上进行分割(比如细胞或者血管)&#xff0c;这里进行眼底血管的分割&#xff0c;用的backbone是VGG16&#xff0c;结构如下如所示(项目里面的图片&#xff0c;借用的&#xff01;借用标记出处&…

C语言函数大全--h开头的函数

C语言函数大全 本篇介绍C语言函数大全–h开头的函数或宏 1. hypot&#xff0c;hypotf&#xff0c;hypotl 1.1 函数说明 函数声明函数功能double hypot(double x, double y);计算直角三角形的斜边长&#xff08;double&#xff09;float hypotf (float x, float y);计算直角…