Fehlermeldung beim Implementieren Sie einer geschachtelten Transaktion mit dem OLE DB-Provider für SQL Server: "Konnte für eine Transaktion für OLE DB-Provider nicht gestartet"

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 306649 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Alles erweitern | Alles schließen

Auf dieser Seite

Problembeschreibung

Microsoft OLE DB-Provider für SQL Server keine geschachtelte Transaktionen unterstützt, und die folgenden Fehlermeldung wird zurückgegeben:
Eine Transaktion für OLE DB-Provider '% 1!' konnte nicht gestartet werden.
Microsoft SQL Server gibt auch eine zurück von der folgenden Fehlermeldung durch, wenn es sich bei der Anbieter einen SQL Server-spezifischen Provider handelt:
Server: Msg 7392, Schweregrad 16, Status 2,
Eine Transaktion für OLE DB-Provider 'SQLOLEDB' konnte nicht gestartet werden. [OLE-DB-Provider meldete: nur eine Transaktion für diese Sitzung aktiv sein kann.]

Ursache

Dieser Fehler besagt versucht wurde, dass eine Anweisung zur Datenänderung für einen OLE DB-Provider auszuführen Wenn die Verbindung in einer expliziten oder impliziten Transaktion und den OLE DB-Provider keine geschachtelte Transaktionen unterstützt. SQL Server benötigt diese Unterstützung, damit bei bestimmten Fehlerbedingungen die Auswirkungen der Anweisung zur Datenänderung beim Fortsetzen der Transaktion beendet werden können.

Lösung

Um dieses Problem zu umgehen, stellen Sie XACT_ABORT auf ON vor der Transaktion ein. Dies bewirkt, dass SQL Server die umgebende Transaktion abgebrochen, tritt ein Fehler während der Verarbeitung der Datenänderungsanweisung. Wenn SET XACT_ABORT auf ist, benötigt SQL Server nicht geschachtelten Transaktionsunterstützung von den OLE DB-Provider.

Status

Es handelt sich hierbei um ein beabsichtigtes Verhalten.

Weitere Informationen

Schritte zum Reproduzieren des Verhaltens

Dieses Beispiel verwendet einen verknüpften Server, der OLE DB-Provider für SQL Server, verwendet um die Auswirkungen der XACT_ABORT erläutern.
  1. Verwenden von OLE DB-Providers für SQL Server um einen Verbindungsserver namens Sales erstellen, Microsoft OLE DB Provider für SQL Server verwendet.
    USE Master
    GO
    EXEC sp_addlinkedserver 
        'Sales',
        N'SQL Server'
    GO
    					
  2. Öffnen Sie Query Analyzer, und führen Sie den folgenden Befehl.
    Begin Transaction
    Insert into Sales.Northwind.DBO.Customers(CustomerId,CompanyName) Values ('1000','Test')
    Commit Transaction
    					
    erhalten Sie die oben erwähnten Fehlermeldung.

    Problemumgehung

  3. Führen Sie den folgenden Befehl aus, um XACT_ABORT auf ON festgelegt:
    Set XACT_ABORT ON
    					
  4. Führen Sie die INSERT -Anweisung erneut aus. Beachten Sie, dass die Daten in der Tabelle ohne Auftreten eines Fehlers eingefügt werden.

Informationsquellen

Weitere Informationen finden Sie folgenden Artikel der Microsoft Knowledge Base:
177138INFO: Geschachtelte Transaktionen in ODBC-OLE DB/ADO nicht verfügbar
187289So wird 's gemacht: Implementieren von geschachtelte Transaktionen mit Oracle

Eigenschaften

Artikel-ID: 306649 - Geändert am: Freitag, 9. Dezember 2005 - Version: 4.2
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2000 Standard Edition
  • Microsoft SQL Server 7.0 Standard Edition
  • Microsoft Data Access Components 2.6
  • Microsoft Data Access Components 2.6 Service Pack 1
Keywords: 
kbmt kbprb KB306649 KbMtde
Maschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 306649
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.

Ihr Feedback an uns

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com