MSSQLSERVER_3988
Si applica a: SQL Server
Dettagli
Attributo | valore |
---|---|
Nome prodotto | SQL Server |
ID evento | 3988 |
Origine evento | MSSQLSERVER |
Componente | SQLEngine |
Nome simbolico | XACT_UNSUPPORT_PARALLEL_TRAN2 |
Testo del messaggio | Non sono consentite nuove transazioni perché nella sessione sono presenti altri thread in esecuzione. |
Spiegazione
Questo errore si verifica quando si esegue una query distribuita che unisce più tabelle ospitate da istanze remote di SQL Server mentre l'impostazione della XACT_ABORT
sessione è ATTIVATA. Viene visualizzato all'utente un messaggio di errore simile al seguente:
Messaggio 3988, livello 16, stato 1, riga #
Non sono consentite nuove transazioni perché nella sessione sono presenti altri thread in esecuzione.
Causa
Esistono alcune limitazioni di progettazione nel modo in cui SQL Server gestisce le query distribuite (DQs) quando sono vere le condizioni seguenti:
- SQL Server unisce più tabelle di un'origine dati di SQL Server remota.
- La sessione che esegue la query non è integrata in una transazione distribuita.
In questa situazione un tentativo di eseguire la query può generare uno dei due errori indicati nella sezione Spiegazione.
Azione utente
Per risolvere il problema, racchiudere la query distribuita in un'istruzione BEGIN DISTRIBUTED TRANSACTION:
BEGIN DISTRIBUTED TRANSACTION
/*The actual Distributed Query goes next, outside of comments*/
COMMIT TRANSACTION