Database Engine 錯誤嚴重性
當 SQL Server Database Engine 產生錯誤時,錯誤的嚴重性會指出 SQL Server 所發生的問題類型。
嚴重性層級
下表列出和描述 SQL Server Database Engine 所產生之錯誤的嚴重性層級。
嚴重性層級 | 描述 |
---|---|
0-9 |
傳回狀態資訊或報告不嚴重之錯誤的參考訊息。Database Engine 不會產生嚴重性 0-9 的系統錯誤。 |
10 |
傳回狀態資訊或報告不嚴重之錯誤的參考訊息。基於相容性考量,Database Engine 會先將嚴重性 10 轉換成嚴重性 0,再將錯誤資訊傳回給發出呼叫的應用程式。 |
11-16 |
指出使用者能夠更正的錯誤。 |
11 |
指出給定的物件或實體不存在。 |
12 |
因特殊查詢提示而不使用鎖定之查詢的特殊嚴重性。在某些情況下,這些陳述式所執行的讀取作業可能會產生不一致的資料,因為並沒有採取鎖定來保證一致性。 |
13 |
指出交易死結錯誤。 |
14 |
指出與安全性相關的錯誤,例如,沒有權限。 |
15 |
指出 Transact-SQL 命令的語法錯誤。 |
16 |
指出使用者能夠更正的一般錯誤。 |
17-19 |
指出使用者無法更正的軟體錯誤。請通知系統管理員這個問題。 |
17 |
指出陳述式使 SQL Server 將資源 (如記憶體、鎖定,或資料庫的磁碟空間) 用完,或超出系統管理員所設定的某項限制。 |
18 |
指出 Database Engine 軟體發生問題,但陳述式執行完成,且 Database Engine 執行個體的連接也得到維護。每當出現嚴重性層級 18 的訊息時,都應該通知系統管理員。 |
19 |
指出超出不可設定的 Database Engine 限制,已終止目前的批次處理序。嚴重性層級 19 或以上的錯誤訊息,會停止執行目前的批次。嚴重性層級 19 的錯誤很少,必須由系統管理員或主要支援提供者來更正。當出現嚴重性層級 19 的訊息時,請連絡您的系統管理員。嚴重性層級 19-25 的錯誤訊息會寫入錯誤記錄中。 |
20-25 |
指出系統問題,這些都是嚴重錯誤,表示執行陳述式或批次的 Database Engine 工作已不在執行中。工作會將發生情況的相關資訊記錄下來,再終止作業。在大部份的情況下,通往 Database Engine 執行個體的應用程式連接也會終止。如果發生這個情況,隨著問題而不同,應用程式可能會無法重新連接。 這個範圍的錯誤訊息可能會影響所有存取相同資料庫之資料的處理序,且可能表示資料庫或物件已經損毀。嚴重性層級 19-25 的錯誤訊息會寫入錯誤記錄中。 |
20 |
指出陳述式發生問題。由於問題只影響到目前的工作,因此,資料庫本身可能並沒有損毀。 |
21 |
指出發生影響目前資料庫中所有工作的問題,但資料庫本身可能並沒有損毀。 |
22 |
指出軟體或硬體問題已損毀訊息所指定的資料表或索引。 嚴重性層級 22 的錯誤很少發生。如果發生,請執行 DBCC CHECKDB 來判斷資料庫中的其他物件是否也已損毀。可能只有緩衝快取發生問題,磁碟本身並沒有問題。若是如此,重新啟動 Database Engine 執行個體便可以更正這個問題。若要繼續作業,您必須重新連接 Database Engine 執行個體;否則,請利用 DBCC 來修復問題。在某些情況下,您可能需要還原資料庫。 如果重新啟動 Database Engine 執行個體仍未更正這個問題,就表示磁碟發生問題。有時終結錯誤訊息所指定的物件可以解決這個問題。例如,如果訊息報告 Database Engine 執行個體在非叢集索引中找到長度是 0 的資料列,請刪除這個索引,再重建它。 |
23 |
指出由於硬體或軟體發生問題,因此,整個資料庫的完整性有問題。 嚴重性層級 23 的錯誤很少發生。如果發生,請執行 DBCC CHECKDB 來判斷損毀的範圍。可能只有快取發生問題,磁碟本身並沒有問題。若是如此,重新啟動 Database Engine 執行個體便可以更正這個問題。若要繼續作業,您必須重新連接 Database Engine 執行個體;否則,請利用 DBCC 來修復問題。在某些情況下,您可能需要還原資料庫。 |
24 |
指出媒體失敗。系統管理員可能需要還原資料庫。您也可能需要電洽您的硬體廠商。 |
使用者自訂的錯誤訊息嚴重性
您可以利用 sp_addmessage,將嚴重性 1-25 的使用者自訂錯誤訊息加入 sys.messages 目錄檢視中。RAISERROR 可以使用這些使用者自訂的錯誤訊息。如需詳細資訊,請參閱<sp_addmessage (Transact-SQL)>。
您可以利用 RAISERROR 來產生嚴重性 1-25 的使用者自訂錯誤訊息。RAISERROR 可以參考 [sys.messages] 目錄檢視中所儲存的使用者自訂錯誤訊息,或動態建立訊息。當在產生錯誤時使用 [sys.messages] 中的使用者自訂錯誤訊息,RAISERROR 指定的嚴重性會覆寫 [sys.messages] 所指定的嚴重性。如需詳細資訊,請參閱<RAISERROR (Transact-SQL)>。
錯誤嚴重性和 TRY…CATCH
TRY…CATCH 建構會捕捉嚴重性大於 10 而並未終止資料庫連接的所有執行錯誤。
嚴重性 0-10 的錯誤是參考訊息,不會使執行動作跳出 TRY…CATCH 建構的 CATCH 區塊。
CATCH 區塊不會處理嚴重性通常是 20-25 的終止資料庫連接的錯誤,因為在連接終止時,會中止執行動作。
如需詳細資訊,請參閱<TRY...CATCH (Transact-SQL)>。
擷取錯誤嚴重性
您可以利用 ERROR_SEVERITY 系統函數來擷取造成執行 TRY…CATCH 建構的 CATCH 區塊之錯誤的嚴重性。如果是在 CATCH 區塊範圍之外呼叫,ERROR_SEVERITY 會傳回 NULL。如需詳細資訊,請參閱<ERROR_SEVERITY (Transact-SQL)>。
請參閱
參考
其他資源
在 Transact-SQL 中擷取錯誤資訊
處理應用程式中的錯誤和訊息
sys.messages (Transact-SQL)
系統函數 (Transact-SQL)
在 Transact-SQL 中使用 TRY...CATCH