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
Freigeben: 2025-01-05 15:54:40
Original
748 Leute haben es durchsucht

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();
        }
    }
}
Nach dem Login kopieren

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);
Nach dem Login kopieren

Späteres Festlegen der Eigenschaft

cmd.Connection = connection;
Nach dem Login kopieren

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
}
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage