Heim >Backend-Entwicklung >C++ >Warum löst „ExecuteNonQuery' in .NET den Fehler „Verbindungseigenschaft nicht initialisiert' aus?

Warum löst „ExecuteNonQuery' in .NET den Fehler „Verbindungseigenschaft nicht initialisiert' aus?

Barbara Streisand
Barbara StreisandOriginal
2025-01-05 15:54:40785Durchsuche

Why Does `ExecuteNonQuery` Throw a

ExecuteNonQuery: Verbindungseigenschaft nicht initialisiert

Problem

Beim Ausführen eines .NET-Programms ist ein Entwickler aufgrund der „ExecuteNonQuery: Verbindungseigenschaft“ auf einen Fehler gestoßen wurde nicht initialisiert“-Meldung.

Codebeispiel

Der folgende Code Beispiel veranschaulicht das Problem:

using System.Data.SqlClient;

namespace Test
{
    class Program
    {
        static void Main()
        {
            SqlConnection connection = new SqlConnection(@"Data Source=.\sqlexpress;Initial Catalog=syslog2;Integrated Security=True");
            SqlCommand cmd = new SqlCommand("INSERT INTO Application VALUES (@EventLog, @TimeGenerated, @EventType, @SourceName, @ComputerName, @InstanceId, @Message) ");

            connection.Open();  // Connection is not assigned to the command
            cmd.ExecuteNonQuery();
            connection.Close();
        }
    }
}

Lösung

Um das Problem zu beheben, muss die Verbindungseigenschaft des SqlCommand zugewiesen werden. Dies kann während der Befehlserstellung oder durch späteres Festlegen der Eigenschaft erfolgen.

Zuweisen während der Befehlserstellung

SqlCommand cmd = new SqlCommand("INSERT INTO Application VALUES (@EventLog, @TimeGenerated, @EventType, @SourceName, @ComputerName, @InstanceId, @Message) ", connection);

Späteres Festlegen der Eigenschaft

cmd.Connection = connection;

Anweisungsempfehlung verwenden

Für Objekte, die IDisposable implementieren, z Als SqlConnection wird die using-Anweisung empfohlen. Die Verbindung wird automatisch geschlossen und alle Ausnahmen werden behandelt:

using (var connection = new SqlConnection(@"Data Source=.\sqlexpress;Initial Catalog=syslog2;Integrated Security=True"))
using (var cmd = new SqlCommand("INSERT INTO Application VALUES (@EventLog, @TimeGenerated, @EventType, @SourceName, @ComputerName, @InstanceId, @Message) "))
{
    cmd.Connection = connection;
    // Connection is automatically closed when leaving the using block
}

Verbindungsverwaltung optimieren

Um die Leistung zu optimieren, ist es nicht erforderlich, für jeden Eintrag in der foreach-Schleife eine neue Verbindung und einen neuen Datenadapter zu erstellen . ADO.NET verwaltet Verbindungen automatisch und verwendet Verbindungspooling.

Das obige ist der detaillierte Inhalt vonWarum löst „ExecuteNonQuery' in .NET den Fehler „Verbindungseigenschaft nicht initialisiert' aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn