Durate delle transazioni
Si applica a:SQL Server
Esiste una differenza importante tra le transazioni avviate in Transact-SQL stored procedure e le transazioni avviate nel codice gestito: il codice CLR (Common Language Runtime) non può sbilanciare lo stato della transazione all'ingresso o all'uscita di una chiamata CLR. Tenere presenti le implicazioni seguenti correlate a questa differenza:
È necessario eseguire il commit o il rollback di una transazione avviata all'interno di un frame CLR oppure sql Server genera un errore quando il frame viene chiuso.
Non è possibile eseguire il commit o il rollback di una transazione esterna all'interno del codice CLR.
Un tentativo di esecuzione del commit di una transazione non avviato nella stessa procedura provoca un errore di runtime.
Un tentativo di eseguire il rollback di una transazione non avviata nella stessa procedura causa l'interruzione della risposta della transazione (impedendo l'esecuzione di qualsiasi altra operazione collaterale). La transazione viene interrotta fino a quando il codice CLR non abbandona l'ambito. Questo comportamento può essere utile quando si rileva un errore all'interno della procedura e si vuole assicurarsi che l'intera transazione venga terminata.