Insertion en bloc

SQLite n’a pas de façon spéciale d’insérer des données en bloc. Pour obtenir des performances optimales lors de l’insertion ou de la mise à jour des données, assurez-vous d’effectuer les opérations suivantes :

  • Utilisez une transaction.
  • Réutilisez la même commande paramétrable. Les exécutions suivantes réutiliseront la compilation de la première.
using (var transaction = connection.BeginTransaction())
{
    var command = connection.CreateCommand();
    command.CommandText =
    @"
        INSERT INTO data
        VALUES ($value)
    ";

    var parameter = command.CreateParameter();
    parameter.ParameterName = "$value";
    command.Parameters.Add(parameter);

    // Insert a lot of data
    var random = new Random();
    for (var i = 0; i < 150_000; i++)
    {
        parameter.Value = random.Next();
        command.ExecuteNonQuery();
    }

    transaction.Commit();
}