Поделиться через


Массовая вставка

SQLite не имеет специального способа массовой вставки данных. Чтобы обеспечить оптимальную производительность при вставке или обновлении данных, убедитесь, что вы выполните следующие действия:

  • Используйте транзакцию.
  • Повторно используйте ту же параметризованную команду. Последующие выполнения повторно используют компиляцию первого.
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();
}