千家信息网

SQL Server内幕之预估与实际执行计划

发表于:2024-11-20 作者:千家信息网编辑
千家信息网最后更新 2024年11月20日,Estimated vs. actual query plans我们可以让SQL server输出计划(对于任何显示计划选项-图形、文本或 XML)是否包含实际运行查询。在不执行查询的情况下生成的查询
千家信息网最后更新 2024年11月20日SQL Server内幕之预估与实际执行计划

Estimated vs. actual query plans


我们可以让SQL server输出计划(对于任何显示计划选项-图形、文本或 XML)是否包含实际运行查询。


在不执行查询的情况下生成的查询计划称为 "预估执行计划 ", 因为 SQL server 可能选择重新编译查询 (由于各种原因可能会发生重编译), 并且可能在执行时生成不同的查询计划。


预估执行计划对于各种用途很有帮助的, 例如查看长时间运行的查询的查询计划而不等待它完成;在不改变数据库状态或获取任何锁的情况下查看插入、更新或删除语句的查询计划;或者在不实际运行查询的情况下, 探索各种优化提示对查询计划的影响。


预估执行计划包括基数、行大小、成本估计数,2012版本新增功能--估计执行模式, 本章后面将对此进行介绍。


提示:优化程序报告的预估成本旨在作为一个指南, 用于比较单个查询计划或两个不同计划的相对成本中的不同运算符的预期相对成本。这些单位预估并不意味着任何绝对意义上的解释, 如毫秒或秒。


执行查询后生成的查询计划称为实际执行计划。实际执行计划包含的信息与估计的执行计划加上实际的行计数和每个运算符的实际处决次数相同。比较估计值和实际行数可以帮助我们识别基数估计错误, 这可能会导致其他计划问题。


提示:实际执行计划包含与预估执行计划相同的成本估计。尽管 SQL server 在生成实际执行计划时实际执行查询计划, 但这些成本估计仍然与优化程序生成的估计值相同, 并且不反映实际的执行成本。


在从 SQL server 管理工作室或 SQLCMD 命令行实用程序运行即席查询时,可以使用几个 transact-sql 命令来收集显示计划选项输出。通过这些命令, 可以收集文本和 XML 计划, 以及预估和实际计划。

表10-1 列出了启用显示计划选项的所有可用 set 命令。

我们还可以使用扩展事件和 XML 计划使用动态管理视图 (DMVs) 来收集查询计划信息。在分析无法访问源代码的应用程序时, 这些选项特别有用。

12章讨论了包含计划信息的 DMVs。


查询 实际 成本 命令 程序 运行 不同 相同 信息 情况 提示 生成 估计值 基数 文本 运算符 帮助 管理 编译 输出 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 金华物流软件开发工具 网络安全信息安全等级分为 网络技术报价表 vnr游戏数据库怎样更新 天津软件开发企业 软件开发过程中质量把控的关键 网络安全基本技术 狼盟网络技术交流论坛 交互式画图软件开发 智园软件开发管理有限公司 软件开发初级t2是什么意思 数据库入门课程 近距离无线通信网络技术 广州web前端软件开发价位 银行软件开发主要是做什么 华为高密度服务器售后维修 宝塔 还原数据库 利信软件网络版需连接服务器 合肥蜀山区互联网科技公司有哪些 乌镇互联网医疗科技有限公司 手机如何炒股软件开发 信子创业北京网络技术有限公司 随手调软件开发单位是在哪里查 软件开发运维部工资会计科目 周口计算机网络技术专业 医疗行业网络安全建设 国内外前10的数据库厂商 近距离无线通信网络技术 网络安全攻防对决 数据库中的语法错误
0