diff options
| author | Gert-Jan Timmer <gjr.timmer@gmail.com> | 2018-05-29 13:19:40 +0200 |
|---|---|---|
| committer | Gert-Jan Timmer <gjr.timmer@gmail.com> | 2018-05-29 13:19:40 +0200 |
| commit | f14a7566f95301542aab53506f6b304e89865f5d (patch) | |
| tree | d17c822350f5feb7d4414f9627ad017b76de0a4f /sqlite3.go | |
| parent | ADD: PRAGMA journal_mode (diff) | |
| download | golite-f14a7566f95301542aab53506f6b304e89865f5d.tar.gz golite-f14a7566f95301542aab53506f6b304e89865f5d.tar.xz | |
ADD: PRAGMA locking_mode
Diffstat (limited to '')
| -rw-r--r-- | sqlite3.go | 29 |
1 files changed, 28 insertions, 1 deletions
@@ -842,6 +842,11 @@ func errorString(err Error) string { // Set journal mode for the databases associated with the current connection. // https://www.sqlite.org/pragma.html#pragma_journal_mode // +// _locking=X +// Sets the database connection locking-mode. +// The locking-mode is either NORMAL or EXCLUSIVE. +// https://www.sqlite.org/pragma.html#pragma_locking_mode +// // _recursive_triggers=Boolean | _rt=Boolean // Enable or disable recursive triggers. // @@ -866,9 +871,10 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) { busyTimeout := 5000 caseSensitiveLike := -1 deferForeignKeys := -1 + foreignKeys := -1 ignoreCheckConstraints := -1 journalMode := "DELETE" - foreignKeys := -1 + lockingMode := "NORMAL" recursiveTriggers := -1 pos := strings.IndexRune(dsn, '?') @@ -1040,6 +1046,19 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) { } } + // Locking Mode (_locking) + // + // https://www.sqlite.org/pragma.html#pragma_locking_mode + // + if val := params.Get("_locking"); val != "" { + switch strings.ToUpper(val) { + case "NORMAL", "EXCLUSIVE": + lockingMode = strings.ToUpper(val) + default: + return nil, fmt.Errorf("Invalid _locking: %v, expecting value of 'NORMAL EXCLUSIVE", val) + } + } + // Recursive Triggers (_recursive_triggers) // // https://www.sqlite.org/pragma.html#pragma_recursive_triggers @@ -1143,6 +1162,14 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) { return nil, err } + // Locking Mode + // Because the default is NORMAL and this is not changed in this package + // by using the compile time SQLITE_DEFAULT_LOCKING_MODE this PRAGMA can always be executed + if err := exec(fmt.Sprintf("PRAGMA locking_mode = %s;", lockingMode)); err != nil { + C.sqlite3_close_v2(db) + return nil, err + } + // Recursive Triggers if recursiveTriggers > -1 { if err := exec(fmt.Sprintf("PRAGMA recursive_triggers = %d;", recursiveTriggers)); err != nil { |
