aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrii Zavorotnii <andrii.zavorotnii@gmail.com>2019-09-23 14:50:49 -0700
committerAndrii Zavorotnii <andrii.zavorotnii@gmail.com>2019-09-23 14:56:04 -0700
commitc4a8658099ed0e92fabcdcd47331dc6a1cebb1f5 (patch)
tree360bcfd97853f87051f3f69caecdd85afd8e5093
parentFix memory leak in ExpandedSQL (#738) (diff)
downloadgolite-c4a8658099ed0e92fabcdcd47331dc6a1cebb1f5.tar.gz
golite-c4a8658099ed0e92fabcdcd47331dc6a1cebb1f5.tar.xz
Fix Open() journal mode regression
[why] see https://github.com/mattn/go-sqlite3/issues/607 SQLite default journal mode is DELETE, but forcing it on open causes "database is locked" if other connection exists with WAL mode, for example. [how] Don't set DELETE mode if not set in DSN explicitly. [testing] Run tests in my project where WAL mode is used.
-rw-r--r--sqlite3.go11
1 files changed, 6 insertions, 5 deletions
diff --git a/sqlite3.go b/sqlite3.go
index 4000173..19f107a 100644
--- a/sqlite3.go
+++ b/sqlite3.go
@@ -1000,7 +1000,7 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) {
deferForeignKeys := -1
foreignKeys := -1
ignoreCheckConstraints := -1
- journalMode := "DELETE"
+ var journalMode string
lockingMode := "NORMAL"
queryOnly := -1
recursiveTriggers := -1
@@ -1571,10 +1571,11 @@ func (d *SQLiteDriver) Open(dsn string) (driver.Conn, error) {
}
// Journal Mode
- // Because default Journal Mode is DELETE this PRAGMA can always be executed.
- if err := exec(fmt.Sprintf("PRAGMA journal_mode = %s;", journalMode)); err != nil {
- C.sqlite3_close_v2(db)
- return nil, err
+ if journalMode != "" {
+ if err := exec(fmt.Sprintf("PRAGMA journal_mode = %s;", journalMode)); err != nil {
+ C.sqlite3_close_v2(db)
+ return nil, err
+ }
}
// Locking Mode