iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >SQL Server的执行计划是什么
  • 657
分享到

SQL Server的执行计划是什么

2023-07-06 04:07:23 657人浏览 薄情痞子
摘要

本文小编为大家详细介绍“sql Server的执行计划是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL Server的执行计划是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一

本文小编为大家详细介绍“sql Server的执行计划是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL Server的执行计划是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    一、背景

    为了能够执行查询,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)。

    • 一个活动的执行计划和一个以前保存的查询执行计划。

    • 查询存储中的两个选定查询计划。

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

    SQL Server的执行计划是什么

    6.2、分析实际执行计划

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

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

    读到这里,这篇“SQL Server的执行计划是什么”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

    --结束END--

    本文标题: SQL Server的执行计划是什么

    本文链接: https://www.lsjlt.com/news/357824.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • SQL Server的执行计划是什么
      本文小编为大家详细介绍“SQL Server的执行计划是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL Server的执行计划是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一...
      99+
      2023-07-06
    • SQL Server中怎么执行计划缓存
      SQL Server中怎么执行计划缓存,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。基础概念SQL Server 有一个用于存储执行计划和数据...
      99+
      2024-04-02
    • SQL Server中怎样执行计划缓存
      今天就跟大家聊聊有关SQL Server中怎样执行计划缓存,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。参数化和非参数化查询计划的唯一标识是查询语句...
      99+
      2024-04-02
    • MySQL的执行计划是什么
      这篇文章给大家介绍MySQL的执行计划是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、前言当我们工作到了一定的年限之后,一些应该掌握的知识点,我们是必须需要去了解的,比如今天面...
      99+
      2024-04-02
    • 什么是SQLServer中的执行计划
      SQL Server中的执行计划是指数据库管理系统在执行SQL查询时生成的用于优化和执行查询的计划。执行计划是一个由数据库引擎生成的...
      99+
      2024-04-02
    • mysql执行计划指的是什么
      这篇文章主要讲解了“mysql执行计划指的是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql执行计划指的是什么”吧! ...
      99+
      2022-11-30
      mysql
    • oracle执行计划的方法是什么
      本篇内容主要讲解“oracle执行计划的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“oracle执行计划的方法是什么”吧!先从最开头一直往右看,直到...
      99+
      2024-04-02
    • mysql怎么查看sql执行计划
      要查看MySQL中SQL语句的执行计划,可以使用EXPLAIN关键字来获取查询的执行计划。以下是使用EXPLAIN来查看SQL执行计...
      99+
      2024-04-15
      mysql
    • oracle中怎么查看sql执行计划的执行顺序
      这篇文章主要讲解了“oracle中怎么查看sql执行计划的执行顺序”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“oracle中怎么查看sql执行计划的执行顺...
      99+
      2024-04-02
    • Oracle中怎么获取SQL执行计划
      这篇文章将为大家详细讲解有关Oracle中怎么获取SQL执行计划,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Oracle 获取SQL执行计划方法方法一:D...
      99+
      2024-04-02
    • 各种数据库的SQL执行计划是怎么样的
      各种数据库的SQL执行计划是怎么样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。执行计划(execution plan,也叫查询计划或者解释...
      99+
      2024-04-02
    • 数据库执行计划原则是什么
      本篇内容介绍了“数据库执行计划原则是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
      99+
      2024-04-02
    • db2如何查看sql执行计划
      在DB2中,您可以使用以下方法查看SQL执行计划: 1、使用EXPLAIN命令:在运行您的SQL查询之前,可以在查询前添加EXPLA...
      99+
      2024-04-12
      db2 sql
    • SQLServer的执行计划
      目录一、背景二、显示和保存执行计划三、显示估计的执行计划四、显示实际执行计划五、以 XML 格式保存执行计划六、比较和分析执行计划6.1、比较执行计划6.2、分析实际执行计划总结一、...
      99+
      2023-05-16
      SQL Server执行计划 SQL Server 执行计划
    • oracle怎么查看SQL执行计划的顺序
      本篇内容介绍了“oracle怎么查看SQL执行计划的顺序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!查看...
      99+
      2024-04-02
    • oracle怎么查看sql历史执行计划
      要查看SQL历史执行计划,可以使用以下方法: 使用Oracle的动态性能视图:通过查询v$sql_plan或v$sql_plan_...
      99+
      2024-04-09
      oracle sql
    • 查看sql 执行计划的历史变更
      查看sql 执行计划的历史变更 oracle 10G 以后可以通过下面的三个视图查询到sql执行计划的历史信息: DBA_HIST_SQL_PLAN DBA_HIST_SQLSTAT DBA_HIST_...
      99+
      2024-04-02
    • MySQL 5.7如何查看SQL执行计划
      这篇文章将为大家详细讲解有关MySQL 5.7如何查看SQL执行计划,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 可以使用EXPLAIN语句...
      99+
      2024-04-02
    • postgres explain如何查看sql执行计划
      这篇文章主要为大家展示了“postgres explain如何查看sql执行计划”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“postgres explain如...
      99+
      2024-04-02
    • MyBatis的SQL执行计划怎么分析与调优
      在MyBatis中,可以通过使用日志功能来查看SQL语句的执行计划,并进行调优。以下是一些分析与调优的方法: 开启MyBatis...
      99+
      2024-05-08
      MyBatis SQL
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作