System.data.sqlite - активация режима журнала WAL - PullRequest
7 голосов
/ 31 декабря 2011

Я использую System.data.sqlite.dll в моей программе vb.net. И я не могу найти код для активации режима WAL.

Активировать ли эту команду сразу после создания базы данных или при каждом новом соединении SQLite.

И если да, то какой код нужно будет использовать сейчас, я использую что-то вроде:

cnn As New SQLiteConnection(String.Format("Data Source={0}\{1};PRAGMA jounal_mode=WAL;", Application.StartupPath, DBName))

это как использовать команду PRAGMA?

Ответы [ 3 ]

8 голосов
/ 10 мая 2012

Вы всегда можете использовать класс 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
    }
3 голосов
/ 26 мая 2012

Это пример строки подключения из моего проекта (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 к базе данных.

1 голос
/ 31 декабря 2011

Вам нужно выполнить прагму как команду-запрос.

Using cmd As SQLiteCommand = cnn.CreateCommand()
   cmd.CommandText = "PRAGMA journal_mode=WAL"
   cmd.ExecuteNonQuery()
End Using

До тех пор, пока вы продолжаете открывать соединение, достаточно один раз установить .

...