欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL Server的執(zhí)行計(jì)劃

 更新時(shí)間:2023年04月17日 09:18:38   作者:Lion Long  
查詢優(yōu)化器的輸出是查詢執(zhí)行計(jì)劃,有時(shí)稱為查詢計(jì)劃或執(zhí)行計(jì)劃。本文主要詳細(xì)介紹了SQL Server的執(zhí)行計(jì)劃,感興趣的同學(xué)可以參考閱讀

一、背景

為了能夠執(zhí)行查詢,SQL Server 數(shù)據(jù)庫(kù)引擎必須分析該語(yǔ)句,以確定訪問所需數(shù)據(jù)的最有效方法。此分析由稱為查詢優(yōu)化器的組件處理。查詢優(yōu)化器的輸入由查詢、數(shù)據(jù)庫(kù)架構(gòu)(表和索引定義)和數(shù)據(jù)庫(kù)統(tǒng)計(jì)信息組成。查詢優(yōu)化器的輸出是查詢執(zhí)行計(jì)劃,有時(shí)稱為查詢計(jì)劃或執(zhí)行計(jì)劃。

查詢執(zhí)行計(jì)劃是以下內(nèi)容的定義:

  • 訪問源表的順序。通常,數(shù)據(jù)庫(kù)服務(wù)器可以在許多序列中訪問基表以生成結(jié)果集。
  • 用于從每個(gè)表中提取數(shù)據(jù)的方法。通常,訪問每個(gè)表中的數(shù)據(jù)有不同的方法。如果只需要具有特定鍵值的幾行,則數(shù)據(jù)庫(kù)服務(wù)器可以使用索引。如果表中的所有行都是必需的,數(shù)據(jù)庫(kù)服務(wù)器可以忽略索引并執(zhí)行表掃描。如果表中的所有行都是必需的,但有一個(gè)索引的鍵列位于 中,則執(zhí)行索引掃描而不是表掃描可能會(huì)保存單獨(dú)的結(jié)果集。如果表非常小,則表掃描可能是幾乎所有訪問表的最有效方法。
  • 用于計(jì)算計(jì)算的方法,以及如何篩選、聚合和排序每個(gè)表中的數(shù)據(jù)。從表中訪問數(shù)據(jù)時(shí),有不同的方法可以對(duì)數(shù)據(jù)執(zhí)行計(jì)算(例如計(jì)算標(biāo)量值),以及聚合和排序查詢文本中定義的數(shù)據(jù),以及如何篩選數(shù)據(jù)。

二、顯示和保存執(zhí)行計(jì)劃

執(zhí)行計(jì)劃以圖形方式顯示 SQL Server 查詢優(yōu)化器選擇的數(shù)據(jù)檢索方法。執(zhí)行計(jì)劃使用圖標(biāo)而不是 SET SHOWPLAN_ALL或 SET SHOWPLAN_TEXT 語(yǔ)句生成的表格表示形式來(lái)表示 SQL Server 中特定語(yǔ)句和查詢的執(zhí)行開銷。這種圖形方法對(duì)于了解查詢的性能特征非常有用。

雖然 SQL Server 查詢優(yōu)化器只生成一個(gè)執(zhí)行計(jì)劃,但存在估計(jì)執(zhí)行計(jì)劃和實(shí)際執(zhí)行計(jì)劃的概念。

  • 估計(jì)的執(zhí)行計(jì)劃返回查詢優(yōu)化器在編譯時(shí)生成的執(zhí)行計(jì)劃。生成估計(jì)的執(zhí)行計(jì)劃不會(huì)實(shí)際執(zhí)行查詢或批處理,因此不包含任何運(yùn)行時(shí)信息,例如實(shí)際資源使用情況指標(biāo)或運(yùn)行時(shí)警告。
  • 實(shí)際執(zhí)行計(jì)劃返回查詢優(yōu)化器生成的執(zhí)行計(jì)劃,并在查詢或批處理完成后返回執(zhí)行計(jì)劃。這包括有關(guān)資源使用情況指標(biāo)和任何運(yùn)行時(shí)警告的運(yùn)行時(shí)信息。

三、顯示估計(jì)的執(zhí)行計(jì)劃

生成估計(jì)的執(zhí)行計(jì)劃時(shí),不會(huì)執(zhí)行 T-SQL 查詢或批處理。因此,估計(jì)的執(zhí)行計(jì)劃不包含任何運(yùn)行時(shí)信息,例如實(shí)際資源使用情況指標(biāo)或運(yùn)行時(shí)警告。相反,生成的執(zhí)行計(jì)劃顯示 SQL Server 數(shù)據(jù)庫(kù)引擎在實(shí)際執(zhí)行查詢時(shí)最有可能使用的查詢執(zhí)行計(jì)劃,并顯示流經(jīng)計(jì)劃中多個(gè)運(yùn)算符的估計(jì)行。

若要使用此功能,用戶必須具有執(zhí)行要為其生成圖形執(zhí)行計(jì)劃的 T-SQL 查詢的適當(dāng)權(quán)限,并且必須向他們授予查詢引用的所有數(shù)據(jù)庫(kù)的 SHOWPLAN 權(quán)限。

通過 SSMS、EXPLAIN 和 SET SHOWPLAN_XML的估計(jì)執(zhí)行計(jì)劃可用于 Azure Synapse Analytics 中的專用 SQL 池(以前稱為 SQL DW)和專用 SQL 池。

注意:使用 SET SHOWPLAN_XML返回每個(gè)語(yǔ)句的執(zhí)行計(jì)劃信息而不執(zhí)行它。

四、顯示實(shí)際執(zhí)行計(jì)劃

實(shí)際執(zhí)行計(jì)劃是在執(zhí)行 T-SQL 查詢或批處理后生成的。因此,實(shí)際執(zhí)行計(jì)劃包含運(yùn)行時(shí)信息,例如實(shí)際資源使用指標(biāo)和運(yùn)行時(shí)警告(如果有)。生成的執(zhí)行計(jì)劃顯示 SQL Server 數(shù)據(jù)庫(kù)引擎用于執(zhí)行查詢的實(shí)際查詢執(zhí)行計(jì)劃。

若要使用此功能,用戶必須具有執(zhí)行正在為其生成圖形執(zhí)行計(jì)劃的 Transact-SQL 查詢的適當(dāng)權(quán)限,并且必須向他們授予查詢引用的所有數(shù)據(jù)庫(kù)的 SHOWPLAN 權(quán)限。

五、以 XML 格式保存執(zhí)行計(jì)劃

要執(zhí)行計(jì)劃功能或使用 XML 顯示計(jì)劃 SET 選項(xiàng),用戶必須具有執(zhí)行要為其生成執(zhí)行計(jì)劃的 Transact-SQL 查詢的適當(dāng)權(quán)限,并且必須向他們授予查詢引用的所有數(shù)據(jù)庫(kù)的 SHOWPLAN 權(quán)限。

使用以下語(yǔ)句打開SHOWPLAN_XML:

SET SHOWPLAN_XML ON;  
GO

若要打開統(tǒng)計(jì)信息 XML,請(qǐng)使用以下語(yǔ)句:

SET STATISTICS XML ON;  
GO

執(zhí)行查詢:

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

六、比較和分析執(zhí)行計(jì)劃

執(zhí)行計(jì)劃以圖形方式顯示 SQL Server 查詢優(yōu)化器選擇的數(shù)據(jù)檢索方法。執(zhí)行計(jì)劃使用圖標(biāo)而不是 SET SHOWPLAN_ALL或 SET SHOWPLAN_TEXT 語(yǔ)句生成的表格表示形式來(lái)表示 SQL Server 中特定語(yǔ)句和查詢的執(zhí)行開銷。這種圖形方法對(duì)于理解查詢的性能特征非常有用。

SQL Server Management Studio 包含的功能允許用戶比較兩個(gè)執(zhí)行計(jì)劃(例如,同一查詢的感知好計(jì)劃和壞計(jì)劃),并執(zhí)行根本原因分析。還包括執(zhí)行單個(gè)查詢計(jì)劃分析的功能,允許通過分析查詢的執(zhí)行計(jì)劃來(lái)深入了解可能影響查詢性能的方案。

6.1、比較執(zhí)行計(jì)劃

出于故障排除原因,數(shù)據(jù)庫(kù)專業(yè)人員可能必須執(zhí)行比較計(jì)劃的功能:

  • 查找查詢或批處理突然變慢的原因。
  • 了解查詢重寫的影響。
  • 觀察引入架構(gòu)設(shè)計(jì)的特定性能增強(qiáng)更改(如新索引)如何有效地更改執(zhí)行計(jì)劃。

可以在以下兩者之間進(jìn)行比較:

  • 兩個(gè)以前保存的執(zhí)行計(jì)劃文件(擴(kuò)展名為 .sqlplan)。
  • 一個(gè)活動(dòng)的執(zhí)行計(jì)劃和一個(gè)以前保存的查詢執(zhí)行計(jì)劃。
  • 查詢存儲(chǔ)中的兩個(gè)選定查詢計(jì)劃。

比較兩個(gè)執(zhí)行計(jì)劃時(shí),計(jì)劃中執(zhí)行基本相同的區(qū)域?qū)⒁韵嗤念伾蛨D案突出顯示。單擊一個(gè)計(jì)劃中的顏色區(qū)域會(huì)將另一個(gè)計(jì)劃居中放在該計(jì)劃中的匹配節(jié)點(diǎn)上。仍然可以比較執(zhí)行計(jì)劃的不匹配運(yùn)算符和節(jié)點(diǎn),但在這種情況下,必須手動(dòng)選擇要比較的運(yùn)算符。

6.2、分析實(shí)際執(zhí)行計(jì)劃

查詢性能故障排除需要在了解查詢處理和執(zhí)行計(jì)劃方面具有豐富的專業(yè)知識(shí),以便能夠?qū)嶋H查找和修復(fù)根本原因。

SQL Server Management Studio 包括在實(shí)際執(zhí)行計(jì)劃分析任務(wù)中實(shí)現(xiàn)某種程度自動(dòng)化的功能,尤其是對(duì)于大型和復(fù)雜的計(jì)劃。目標(biāo)是更輕松地查找基數(shù)估計(jì)不準(zhǔn)確的方案,并獲取有關(guān)可能可用的緩解措施的建議。

總結(jié)

  • 實(shí)際執(zhí)行計(jì)劃是在事務(wù)處理 SQL 查詢或批處理執(zhí)行后生成的。因此,實(shí)際執(zhí)行計(jì)劃包含運(yùn)行時(shí)信息,例如實(shí)際行數(shù)、資源使用指標(biāo)和運(yùn)行時(shí)警告(如果有)。
  • 只有考慮更改計(jì)劃形狀的節(jié)點(diǎn)才會(huì)用于檢查相似性。因此,在計(jì)劃同一子部分中的兩個(gè)節(jié)點(diǎn)的中間可能存在一個(gè)未著色的節(jié)點(diǎn)。在這種情況下,缺少顏色意味著在檢查部分是否相等時(shí)未考慮節(jié)點(diǎn)。
  • 在將建議的緩解措施應(yīng)用于生產(chǎn)環(huán)境之前,請(qǐng)確保對(duì)其進(jìn)行適當(dāng)?shù)臏y(cè)試。

到此這篇關(guān)于SQL Server的執(zhí)行計(jì)劃的文章就介紹到這了,更多相關(guān)SQL執(zhí)行計(jì)劃內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • sql 截取域名的問題

    sql 截取域名的問題

    sql 截取域名的幾種方法總結(jié),需要的朋友可以參考一下
    2013-03-03
  • SQL Server定時(shí)收縮數(shù)據(jù)庫(kù)日志為指定大小的示例代碼

    SQL Server定時(shí)收縮數(shù)據(jù)庫(kù)日志為指定大小的示例代碼

    SQL Server提供了DBCC SHRINKFILE 命令來(lái)清理事務(wù)日志文件,該命令可以縮小指定文件的大小,并釋放磁盤空間,本文給大家介紹了SQL Server如何定時(shí)收縮數(shù)據(jù)庫(kù)日志為指定大小,需要的朋友可以參考下
    2024-03-03
  • SQL?Server中使用表變量和臨時(shí)表

    SQL?Server中使用表變量和臨時(shí)表

    這篇文章介紹了SQL?Server中使用表變量和臨時(shí)表的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • Sqlserver 常用日期時(shí)間函數(shù)

    Sqlserver 常用日期時(shí)間函數(shù)

    Sqlserver中經(jīng)常要操作一些時(shí)間類型的字段轉(zhuǎn)換,我又不太記得住,記在這里方便自己以后要用的時(shí)候?qū)ふ遥麑?duì)大家也有幫助.
    2010-06-06
  • SQL語(yǔ)句執(zhí)行順序詳解

    SQL語(yǔ)句執(zhí)行順序詳解

    本文給大家介紹SQL語(yǔ)句執(zhí)行順序詳解,涉及到sql語(yǔ)句執(zhí)行順序相關(guān)知識(shí),對(duì)sql語(yǔ)句執(zhí)行順序感興趣的朋友一起看看吧
    2015-10-10
  • 參考sql2012存儲(chǔ)過程寫的統(tǒng)計(jì)所有用戶表尺寸大小的示例

    參考sql2012存儲(chǔ)過程寫的統(tǒng)計(jì)所有用戶表尺寸大小的示例

    參考SQL2005, 2008和2012的系統(tǒng)存儲(chǔ)過程master.sys.sp_spaceused代碼后,寫了下面一條語(yǔ)句來(lái)方便平時(shí)統(tǒng)計(jì)所有用戶表尺寸大小
    2014-01-01
  • Sql server端口未打開連接不上的解決方案

    Sql server端口未打開連接不上的解決方案

    這篇文章主要給大家介紹了關(guān)于Sql server端口未打開連接不上的解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Sql server具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • SQL Server 觸發(fā)器實(shí)例詳解

    SQL Server 觸發(fā)器實(shí)例詳解

    觸發(fā)器是一種特殊類型的存儲(chǔ)過程,它不同于之前的我們介紹的存儲(chǔ)過程。觸發(fā)器主要是通過事件進(jìn)行觸發(fā)被自動(dòng)調(diào)用執(zhí)行的,接下來(lái)本文通過實(shí)例詳解sqlserver觸發(fā)器,對(duì)sqlserver觸發(fā)器相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • SQL處理多級(jí)分類,查詢結(jié)果呈樹形結(jié)構(gòu)

    SQL處理多級(jí)分類,查詢結(jié)果呈樹形結(jié)構(gòu)

    對(duì)于多級(jí)分類常規(guī)的處理方法,很多程序員可能是用程序先讀取一級(jí)分類記錄,然后通過一級(jí)分類循環(huán)讀取下面的子分類
    2012-08-08
  • SQL臨時(shí)表遞歸查詢子信息并返回記錄的代碼

    SQL臨時(shí)表遞歸查詢子信息并返回記錄的代碼

    SQL臨時(shí)表遞歸查詢子信息并返回記錄的代碼,需要的朋友可以參考下
    2012-08-08

最新評(píng)論