共用方式為


交易隔離等級

適用於:SQL Server Azure SQL 受控執行個體

SQL Server 不保證透過目錄檢視、相容性檢視、資訊結構描述檢視,以及發出中繼資料的內建函數來存取中繼資料的查詢,一定接受鎖定提示。

就內部而言,SQL Server 資料庫引擎只接受中繼資料存取的 READ COMMITTED 隔離等級。 例如,如果某交易的隔離等級為 SERIALIZABLE,且交易中試圖以目錄檢視或發出中繼資料的內建函數來存取中繼資料,這些查詢會持續執行到其成為 READ COMMITTED 為止。 但在快照隔離下,對中繼資料的存取可能會因並行的 DDL 作業而失敗。 這是因為中繼資料並未建立版本。 因此,在快照隔離下存取下列項目可能會失敗:

  • 目錄檢視

  • 相容性檢視

  • 資訊結構描述檢視

  • 發出中繼資料的內建函數

  • 預存程序的 sp_help 群組

  • SQL Server Native Client 目錄程序

  • 動態管理檢視與函數

如需隔離等級的詳細資訊,請參閱 SET TRANSACTION ISOLATION LEVEL (Transact-SQL)

下表提供在各種隔離等級下存取中繼資料的摘要。

隔離等級 支援 接受
READ UNCOMMITTED No 不保證
READ COMMITTED
REPEATABLE READ
SNAPSHOT ISOLATION
SERIALIZABLE