Fehlermeldung, wenn Sie die SqlBulkCopy-Klasse, verwenden um Daten aus einer Ressource in einer Datentabelle in .NET Framework 2.0 zu kopieren: "System.InvalidOperationException: Spalte Sortierungsinformationen für die Zieltabelle aufgerufen"

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

Auf dieser Seite

Problembeschreibung

In einer Microsoft .NET Framework 2.0-Anwendung verwenden Sie die SqlBulkCopy -Klasse, um Daten aus einer System.Data.DataTable zu einer Tabelle in Microsoft SQL Server kopieren. Wenn der Name der Tabelle ein Zeichen Punkt (.) enthält, erhalten Sie folgende Fehlermeldung:
System.InvalidOperationException wurde nicht behandelt
Nachricht = "Fehler beim Spalte Sortierungsinformationen für die Zieltabelle zu erhalten. Wenn die Tabelle nicht in der aktuellen Datenbank ist der Name mithilfe des Datenbanknamens gekennzeichnet werden muss (z. B. [Mydb]...[Mytable](z. B. [Mydb]...[Mytable]); dies gilt auch für temporäre-Tabellen (z. B. #mytable würde etwa Tempdb angegeben werden...#MyTable). "
Source="System.Data"

Ursache

Dieses Problem wird durch ein Problem in der System.Data.dll verursacht Datei.

Abhilfe

Dieses Problem zu umgehen, vermeiden Sie Punkt-Zeichen (.) im Tabellennamen.

Wenn Sie haben ein Zeichen Punkt (.) in einem Tabellennamen verwenden möchten, verwenden Sie das Zeichen Punkt (.) als Teil der SQL-Namenskonvention. Verwenden Sie beispielsweise, einen Tabellennamen, der der folgenden ähnelt:
tablename Server.Database.Schema.

Status

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

Weitere Informationen

Schritte zum Reproduzieren des Verhaltens

  1. Führen Sie in der Northwind-Datenbank die folgende SQL-Anweisung:
    select * into [test.33] where 1 = 0
    --Create a table named [test.33].
    
  2. Erstellen eine Visual C#-Anwendung und führen Sie den folgenden Code:
    static void Main(string[] args)
            {
                SqlConnection con = new SqlConnection("Integrated Security=SSPI;Initial Catalog=Northwind;Data Source=.");
                con.Open();
                SqlConnection dst = new SqlConnection("Integrated Security=SSPI;Initial Catalog=Northwind;Data Source=.");
                dst.Open();
                SqlCommand com = new SqlCommand("select * from customers", con);
                SqlDataReader dr = com.ExecuteReader();
                SqlBulkCopy sbc = new SqlBulkCopy(dst);
                sbc.DestinationTableName = "Northwind.dbo.[Test.33]";
                sbc.WriteToServer(dr); // The failure occurs here.
                dst.Close();
                con.Close();
            }
    

Aufruflisteninformationen

at System.Data.SqlClient.SqlBulkCopy.AnalyzeTargetAndCreateUpdateBulkCommand(BulkCopySimpleResultSet internalResults)
       at System.Data.SqlClient.SqlBulkCopy.WriteToServerInternal()
       at System.Data.SqlClient.SqlBulkCopy.WriteRowSourceToServer(Int32 columnCount)
       at System.Data.SqlClient.SqlBulkCopy.WriteToServer(IDataReader reader)

Eigenschaften

Artikel-ID: 944389 - Geändert am: Donnerstag, 3. Januar 2008 - Version: 2.1
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft .NET Framework 2.0
  • Microsoft .NET Framework 3.0
  • Microsoft .NET Framework 3.5
Keywords: 
kbmt kbexpertiseadvanced kbtshoot kbprb KB944389 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: 944389
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