Heim >Backend-Entwicklung >C++ >Warum löst „ExecuteNonQuery' in .NET den Fehler „Verbindungseigenschaft nicht initialisiert' aus?
Beim Ausführen eines .NET-Programms ist ein Entwickler aufgrund der „ExecuteNonQuery: Verbindungseigenschaft“ auf einen Fehler gestoßen wurde nicht initialisiert“-Meldung.
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(); } } }
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;
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 }
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!