Gravità degli errori del Motore di database

Negli errori generati da Motore di database di SQL Server, la gravità dell'errore indica il tipo di problema rilevato da SQL Server.

Livelli di gravità

Nella tabella seguente sono elencati e descritti i livelli di gravità degli errori generati da Motore di database di SQL Server.

Livello di gravità

Descrizione

0-9

Messaggi informativi che restituiscono dettagli sullo stato o segnalano errori non gravi. Motore di database non genera errori di sistema con livelli di gravità compresi tra 0 e 9.

10

Messaggi informativi che restituiscono dettagli sullo stato o segnalano errori non gravi. Per motivi di compatibilità, Motore di database converte il livello di gravità 10 nel livello di gravità 0 prima di restituire informazioni sull'errore all'applicazione chiamante.

11-16

Indicano errori che possono essere corretti dall'utente.

11

Indica che l'entità o l'oggetto specificato non esiste.

12

Livello di gravità distinto per le query che non utilizzano il blocco a causa di hint per query speciali. In alcuni casi, le operazioni di lettura eseguite da queste istruzioni possono generare dati inconsistenti, poiché non vengono acquisiti blocchi per garantire la consistenza.

13

Indica errori di deadlock di transazione.

14

Indica errori relativi alla sicurezza, ad esempio un'autorizzazione negata.

15

Indica errori di sintassi nel comando Transact-SQL.

16

Indica errori generali che possono essere corretti dall'utente.

17-19

Indicano errori software che possono essere corretti dall'utente. È consigliabile informare l'amministratore di sistema del problema.

17

Indica che l'istruzione ha causato l'esaurimento delle risorse di SQL Server, ad esempio memoria, blocchi o spazio su disco per il database, oppure il superamento di un limite impostato dall'amministratore di sistema.

18

Indica un problema nel software di Motore di database, ma viene completata l'esecuzione dell'istruzione e viene mantenuta la connessione all'istanza di Motore di database. Ogni volta che viene visualizzato un messaggio con livello di gravità 18, è consigliabile informare l'amministratore di sistema.

19

Indica che è stato superato un limite di Motore di database non configurabile e che è stata terminata l'elaborazione batch corrente. I messaggi di errore con livello di gravità 19 o superiore arrestano l'esecuzione del batch corrente. Gli errori con livello di gravità 19 sono rari e devono essere corretti dall'amministratore di sistema o dal supporto tecnico. Se viene generato un messaggio con livello di gravità 19, rivolgersi all'amministratore di sistema. I messaggi di errore con livello di gravità compreso tra 19 e 25 vengono scritti nel registro errori.

20-24

Indicano problemi di sistema e rappresentano errori irreversibili. Pertanto, l'attività di Motore di database che esegue un'istruzione o un batch non è più in esecuzione. L'attività registra le informazioni sul problema che si è verificato e termina l'esecuzione. Nella maggior parte dei casi è possibile che venga terminata anche la connessione dell'applicazione all'istanza di Motore di database e, a seconda del problema, l'applicazione potrebbe non essere in grado di eseguire la riconnessione.

I messaggi di errore compresi in questo intervallo possono riguardare tutti i processi che accedono ai dati dello stesso database e potrebbero indicare che un database o un oggetto è danneggiato. I messaggi di errore con livello di gravità compreso tra 19 e 24 vengono scritti nel registro errori.

20

Indica che si è verificato un problema relativo a un'istruzione. Poiché il problema riguarda solo l'attività corrente, è probabile che il database non sia stato danneggiato.

21

Indica che si è verificato un problema che riguarda tutte le attività del database corrente, ma è probabile che il database non sia stato danneggiato.

22

Indica che la tabella o l'indice specificato nel messaggio è stato danneggiato a causa di un problema software o hardware.

Gli errori con livello di gravità 22 si verificano raramente. Se viene generato un tale errore, eseguire DBCC CHECKDB per determinare se sono stati danneggiati anche altri oggetti contenuti nel database. Il problema potrebbe essere limitato esclusivamente alla cache buffer e non riguardare il disco. In tal caso, è possibile correggere il problema riavviando l'istanza di Motore di database. Per continuare a lavorare, è necessario riconnettersi all'istanza di Motore di database; in alternativa, risolvere il problema utilizzando DBCC. In alcuni casi, potrebbe essere necessario ripristinare il database.

Se il problema persiste dopo il riavvio dell'istanza di Motore di database, il problema è presente sul disco. L'eliminazione dell'oggetto specificato nel messaggio di errore consente talvolta di risolvere il problema. Se ad esempio il messaggio segnala che l'istanza di Motore di database ha rilevato una riga con lunghezza pari a 0 in un indice non cluster, è sufficiente eliminare l'indice e ricompilarlo.

23

Indica che l'integrità dell'intero database è compromessa a causa di un problema hardware o software.

Gli errori con livello di gravità 23 si verificano raramente. Se viene generato un tale errore, eseguire DBCC CHECKDB per determinare l'entità del danno. Il problema potrebbe essere limitato esclusivamente alla cache e non riguardare il disco. In tal caso, è possibile correggere il problema riavviando l'istanza di Motore di database. Per continuare a lavorare, è necessario riconnettersi all'istanza di Motore di database; in alternativa, risolvere il problema utilizzando DBCC. In alcuni casi, potrebbe essere necessario ripristinare il database.

24

Indica un errore del supporto. È possibile che l'amministratore di sistema debba ripristinare il database. Potrebbe anche essere necessario rivolgersi al fornitore dell'hardware.

Gravità dei messaggi di errore definiti dall'utente

La stored procedure sp_addmessage consente di aggiungere messaggi di errore definiti dall'utente con livelli di gravità compresi tra 1 e 25 alla vista del catalogo sys.messages. Tali messaggi di errore definiti dall'utente possono essere utilizzati da RAISERROR. Per ulteriori informazioni, vedere sp_addmessage (Transact-SQL).

È possibile utilizzare RAISERROR per generare messaggi di errore definiti dall'utente con livelli di gravità compresi tra 1 e 25. Con RAISERROR si può fare riferimento a un messaggio di errore definito dall'utente archiviato nella vista del catalogo sys.messages oppure compilare un messaggio in modo dinamico. Quando si utilizza il messaggio di errore definito dall'utente nella vista del catalogo sys.messages durante la generazione di un errore, la gravità specificata da RAISERROR sostituisce quella specificata in sys.messages. Per ulteriori informazioni, vedere RAISERROR (Transact-SQL).

Gravità dell'errore e costrutto TRY…CATCH

Un costrutto TRY…CATCH rileva tutti gli errori di esecuzione con gravità superiore a 10 che non terminano la connessione al database.

Gli errori con gravità compresa tra 0 e 10 sono messaggi informativi e non causano l'esecuzione del blocco CATCH di un costrutto TRY…CATCH.

Gli errori che terminano la connessione al database, in genere con gravità compresa tra 20 e 25, non vengono gestiti dal blocco CATCH in quanto l'esecuzione viene interrotta al termine della connessione.

Per ulteriori informazioni, vedere TRY...CATCH (Transact-SQL).

Recupero della gravità dell'errore

La funzione di sistema ERROR_SEVERITY consente di recuperare la gravità dell'errore che ha causato l'esecuzione del blocco CATCH di un costrutto TRY…CATCH. ERROR_SEVERITY restituisce NULL se chiamata al di fuori dell'ambito di un blocco CATCH. Per ulteriori informazioni, vedere ERROR_SEVERITY (Transact-SQL).