Artikel-ID: 225042 - Geändert am: Donnerstag, 23. Oktober 2003 - Version: 2.1

Fehler: Fehlermeldung: Fehler "80004005" Unerwarteter Fehler

SystemtippDieser Artikel bezieht sich auf ein anderes Betriebssystem als das von Ihnen verwendete. Für Sie möglicherweise nicht relevante Artikelinhalte wurden deaktiviert.

Auf dieser Seite

Alles erweitern | Alles schließen

Problembeschreibung

Innerhalb des Codes MDAC haben Sie mehrere Recordsets mit dem gleichen Recordsetobjekt, das von den gleichen Befehl erstellt werden und sind auch auf die gleiche Verbindung zeigen. Das erste Recordset, das geöffnet wird, enthält mehrere Recordsets in demselben Objekt. Vor dem Aufruf NextRecordset für das Objekt, öffnen Sie ein anderes Recordset (neue Recordsetobjekt), und zeigen Sie die ActiveConnection -Eigenschaft auf den gleichen Befehl und die Verbindung, bei anderen Recordset-Objekt verweist wurde. Dadurch wird den folgenden Fehler bei der Set Rs = rs.NextRecordset wird ausgeführt:
Fehler '80004005 ' bei Unbekannter Fehler
Dieser Fehler tritt in MDAC 2.0 und MDAC 2.1. Es tritt nicht in MDAC 1.5.

Lösung

Stellen Sie sicher, dass die ActiveConnection -Eigenschaft des Command -Objekts für das erste Recordset nur einmal in der gesamten Seite festgelegt ist (insbesondere wenn es mehrere physische Recordsets innerhalb des gleichen Recordset-Objekts enthält) Wenn dieselbe Verbindung verwendet wird.

Status

Microsoft hat bestätigt, dass es sich hierbei um ein Problem bei den in diesem Artikel Microsoft-Produkten handelt.

Dieser Bug wurde in MDAC 2.5 behoben.

Weitere Informationen

Schritte zum Reproduzieren des Verhaltens

  1. Öffnen Sie eine neue Active Server Pages (ASP)-Seite in Visual InterDev und fügen Sie folgenden Code auf das Zeichenblatt:
    <%@ Language=VBScript %>
    <%
            Set cn = Server.CreateObject("ADODB.Connection")
    	cn.Open "pubs","sa",""
    	Set cmd = Server.CreateObject("ADODB.Command")
    	Set rs = Server.CreateObject("ADODB.Recordset")	
    	cmd.CommandText = "Select * From Authors Select * From Stores Select * From Sales"
    	cmd.CommandType = 1
    	Set cmd.ActiveConnection = cn
            rs.Open cmd
    	Response.Write(rs(0) & "<BR>")
    	
    	GetDBValues	
    
            Response.Write(rs(0) & "<BR>")
            Response.Write(rs(1) & "<BR>")
        
            Set rs = rs.NextRecordset 'Fails on this line
       
            Response.Write("New Recordset after NextRecordset Call" & "<BR>")
            Response.Write(rs(0) & "<BR>")
            Response.Write(rs(1) & "<BR>")
    	
      Sub GetDBValues
    	
    	Set rst = Server.CreateObject("ADODB.Recordset")
    	cmd.CommandText = "Select * from stores" 
    	cmd.CommandType = 1
    	Set cmd.ActiveConnection = cn
    
    	rst.Open cmd
    	Response.Write("Opened new recordset" & "<BR>")
      End Sub		
      %> 
    
    					
  2. Erstellen Sie einen Datenquellennamen (DSN) namens "Pubs", der auf die Pubs-Datenbank auf SQL Server zeigt.
  3. Führen Sie die Seite, und die folgende Fehlermeldung angezeigt:
    "80004005 ' Bei"Unbekannter Fehler"

Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft Data Access Components 2.0
  • Microsoft Data Access Components 2.1
Keywords: 
kbmt kbbug kbmdac250fix KB225042 KbMtde
Maschinell übersetzter ArtikelMaschinell ü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: 225042  (http://support.microsoft.com/kb/225042/en-us/ )
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.