Impossible d'exécuter une requête à l'aide de ExecuteNonQuery : connexion non initialisée
Un problème récurrent survient lors de la tentative d'exécution d'une requête à l'aide de ExecuteNonQuery :
ExecuteNonQuery: Connection property has not been initialized.
Explication
Cette erreur se produit lorsque la propriété Connection de l’objet SqlCommand n’est pas affectée. La propriété Connection établit la connexion entre SqlCommand et la base de données. Sans connexion établie, ExecuteNonQuery ne peut pas être exécuté.
Solution
Pour résoudre ce problème, attribuez la connexion à la base de données à la propriété Connection de l'objet SqlCommand :
cmd.InsertCommand.Connection = connection1;
De plus, il est conseillé d'utiliser l'instruction using pour les ressources jetables comme SqlConnection. Cette pratique garantit une élimination appropriée des ressources et gère la fermeture des connexions :
using (var connection1 = new SqlConnection(@"Data Source=.\sqlexpress;Initial Catalog=syslog2;Integrated Security=True")) { using (var cmd = new SqlDataAdapter()) { using (var insertCommand = new SqlCommand("INSERT INTO Application VALUES (@EventLog, @TimeGenerated, @EventType, @SourceName, @ComputerName, @InstanceId, @Message) ")) { // Assign connection insertCommand.Connection = connection1; // Set other properties... connection1.Open(); // Execute query... } } }
Optimisation
Pour optimiser davantage les performances, évitez de créer plusieurs connexions et adaptateurs de données pour chaque itération d'un boucle. Établissez la connexion et l'adaptateur de données une fois en dehors de la boucle et réutilisez-les dans la boucle. Cela réduit les frais liés à la création et à la fermeture de connexions plusieurs fois.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!