Inserção em massa

O SQLite não tem nenhuma maneira especial de inserir dados em massa. Para obter o desempenho ideal ao inserir ou atualizar dados, verifique se você faz o seguinte:

  • Use uma transação.
  • Reutilize o mesmo comando parametrizado. As execuções subsequentes reutilizarão a compilação da primeira.
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();
}