Update: Sie können keine Tabellen zuzugreifen, die in einer SQL Server-Transaktion verwendet werden, wenn Sie den Thread, der die Transaktion ausführt beenden, bevor die Transaktion abgeschlossen ist in .NET Framework 2.0

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

Auf dieser Seite

Problembeschreibung

Stellen Sie sich das folgende Szenario vor. Erstellen Sie eine Anwendung, die auf .NET Framework 2.0 basiert. In der Anwendung verwenden Sie ein SqlConnection-Objekt um eine Verbindung zu Microsoft SQL Server öffnen. Sie haben eine Transaktion für die Verbindung ausführen. Vor Abschluss die Transaktion rufen Sie jedoch die Abort-Methode des Threads, die die Transaktion ausgeführt wird. In diesem Szenario kann keine Abfrage eine Tabelle, die in der Transaktion verwendet wird erfolgreich abgeschlossen.

Dieses Problem kann auftreten, wenn folgende Bedingungen erfüllt sind:
  • Die Anwendung ist eine Webanwendung.
  • Die Transaktion dauert sehr lange um fertig zu stellen.
Dieses Problem wird nicht in .NET Framework 1.0 oder .NET Framework 1.1.

Dieses Problem tritt auch in .NET Framework 2.0 mit Service Pack 1 (SP1).
Weitere Informationen zu einem Hotfix, der dieses Problem in .NET Framework 2.0 mit Service Pack 1 behebt, finden Sie im folgenden Artikel der Microsoft Knowledge Base:
948864Update: Sie können keine Tabellen zuzugreifen, die in einer SQL Server-Transaktion verwendet werden, wenn Sie den Thread, der die Transaktion ausführt beenden, bevor die Transaktion abgeschlossen ist in .NET Framework 2.0 Service Pack 1

Ursache

Dieses Problem rührt von .NET Framework 2.0 nicht bereinigen das SqlConnection-Objekt einrichten. Transaktionen, die das SqlConnection-Objekt verwaltet sind weiterhin aktiv. Daher behalten diese Transaktionen Sperren auf Tabellen oder Tabellenzeilen bis die Anwendung beendet.

Wird bei eine Webanwendung ein SqlConnection-Objekt verwendet zum Ausführen einer Transaktion, IIS-Aufrufe die Abort-Methode des Threads, die die Transaktion ausgeführt, wird wenn die Transaktion Zeit der Wert der HttpRuntimeSection.ExecutionTimeout-Eigenschaft des IIS überschreitet. Daher verwaltet diese Buchung Sperren auf Tabellen oder Tabellenzeilen, bis den Anwendungspool neu gestartet.

Hinweis: Standardmäßig ist der Wert der HttpRuntimeSection.ExecutionTimeout-Eigenschaft 90. Dieser Wert stellt 90 Sekunden.

Lösung

Hotfix-Informationen

Ein unterstützter Hotfix ist inzwischen von Microsoft. Es ist jedoch nur die Behebung des Problems die in diesem Artikel beschriebene vorgesehen. Wenden Sie es nur auf Systemen, bei die dieses spezielle Problem auftritt. Dieser Hotfix wird unter Umständen zu einem späteren Zeitpunkt weiteren Tests unterzogen. Wenn Sie durch dieses Problem nicht schwerwiegend betroffen sind, empfiehlt Microsoft daher, auf das nächste .NET Framework 2.0 Servicepack warten, das diesen Hotfix enthält wird.

Dieses Problem sofort beheben möchten, wenden Sie sich an Microsoft Support Services, um den Hotfix zu erhalten. Eine vollständige Liste mit Telefonnummern der Microsoft Product Support Services und Informationen über Supportkosten der folgenden Microsoft-Website:
http://support.microsoft.com/contactus/?ws=support
Hinweis: PLEASE DO NOT TRANSLATE and DELETE THIS PASSAGE. IT DOES NOT APPLY TO GERMANY.

Voraussetzungen

Es gibt keine Voraussetzungen für diesen Hotfix.

Neustartanforderung

Sie müssen den Computer nach Installation dieses Hotfixes neu starten.

Ersetzte Hotfixes

Dieser Hotfix ersetzt keine anderen Hotfixes.

Dateiinformationen

Die englische Version dieses Hotfixes weist die Dateiattribute (oder höher Dateiattribute), die in der folgenden Tabelle aufgelistet werden. Die Datums- und Uhrzeitangaben für diese Dateien sind in Coordinated Universal Time (UTC) angegeben. Wenn Sie sich die Dateiinformationen ansehen, werden diese Angaben in die lokale Zeit konvertiert. Verwenden Sie die Registerkarte Zeitzone im Element Datum und Uhrzeit in der Systemsteuerung, um die Differenz zwischen UTC und der Ortszeit zu ermitteln.
.NET Framework 2.0 x 86-basierte Versionen
Tabelle minimierenTabelle vergrößern
DateinameDateiversionDateigrößeDatumUhrzeitPlattform
System.Data.dll2.0.50727.9482,903,55226-Oct-200703: 22X 86
.NET Framework 2.0 x 64-basierte Versionen
Tabelle minimierenTabelle vergrößern
DateinameDateiversionDateigrößeDatumUhrzeitPlattform
System.Data.dll2.0.50727.9482,969,60025-Oct-200722: 49X 64
System.Data.dll2.0.50727.9482,903,55226-Oct-200703: 22X 86
.NET Framework 2.0, Itanium-Architektur Versionen
Tabelle minimierenTabelle vergrößern
DateinameDateiversionDateigrößeDatumUhrzeitPlattform
System.Data.dll2.0.50727.9483,111,93626-Oct-200700: 05IA-64
System.Data.dll2.0.50727.9482,903,55226-Oct-200703: 22X 86

Status

Microsoft hat bestätigt, dass dies ein Problem in Microsoft-Produkten handelt, die im Abschnitt "Gilt für" aufgeführt sind.

Weitere Informationen

Weitere Informationen zu verwandten Problemen finden Sie im folgenden Artikel der Microsoft Knowledge Base:
821268Konflikte, Leistungseinbußen und Deadlocks, wenn Sie Webdienstanforderungen aus ASP.NET-Anwendungen
Weitere Informationen zur Terminologie für Softwareupdates finden Sie im folgenden Artikel der Microsoft Knowledge Base:
824684Erläuterung von Standardbegriffen bei Microsoft Softwareupdates

Eigenschaften

Artikel-ID: 944100 - Geändert am: Dienstag, 15. April 2008 - Version: 2.0
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft .NET Framework 2.0
Keywords: 
kbmt kbexpertiseadvanced kbexpertiseinter kbpubtypekc kbqfe kbfix KB944100 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: 944100
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