Система.данные.sqlite-активация режима журнала WAL
Я использую систему.данные.базы данных SQLite.dll в моем vb.net программа. И, хоть убей, я не могу понять код для активации режима WAL.
активировать эту команду сразу после создания БД или с каждым новым SQLiteConnection.
и если да, то какой код нужно было бы использовать прямо сейчас im, используя что-то вроде:
cnn As New SQLiteConnection(String.Format("Data Source={0}{1};PRAGMA jounal_mode=WAL;", Application.StartupPath, DBName))
так ли должна использоваться команда PRAGMA?
3 ответов
вы всегда можете использовать SQLiteConnectionStringBuilder
класс, чтобы сделать работу за вас:
SQLiteConnectionStringBuilder connBuilder = new SQLiteConnectionStringBuilder();
connBuilder.DataSource = filePath;
connBuilder.Version = 3;
//Set page size to NTFS cluster size = 4096 bytes
connBuilder.PageSize = 4096;
connBuilder.CacheSize = 10000;
connBuilder.JournalMode = SQLiteJournalModeEnum.Wal;
connBuilder.Pooling = true;
connBuilder.LegacyFormat = false;
connBuilder.DefaultTimeout = 500;
connBuilder.Password = "yourpass";
using(SQLiteConnection conn = new SQLiteConnection(connBuilder.ToString()))
{
//Database stuff
}
это пример строки подключения из моего проекта (App.config):
<connectionStrings>
<add name="SQLiteDb" providerName="System.Data.SQLite" connectionString="Data Source=data.sqlite;Version=3;Pooling=True;Synchronous=Off;journal mode=Memory"/>
</connectionStrings>
вместо journal mode=Memory
вы можете указать journal mode=WAL
.
если в строке подключения не указан режим журнала, его можно переключить вручную, выполнив PRAGMA jounal_mode=WAL
запрос к базе данных.
необходимо выполнить ПРАГМА в командной запросами.
Using cmd As SQLiteCommand = cnn.CreateCommand()
cmd.CommandText = "PRAGMA journal_mode=WAL"
cmd.ExecuteNonQuery()
End Using
пока вы держите соединение открытым, установка этого один раз будет достаточно.