Compartir a través de


Inserción masiva

SQLite no tiene ninguna manera especial de insertar datos de forma masiva. Para obtener un rendimiento óptimo al insertar o actualizar datos, asegúrese de hacer lo siguiente:

  • Use una transacción.
  • Vuelva a usar el mismo comando con parámetros. Las ejecuciones posteriores reutilizarán la compilación de la primera.
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();
}