Golang SQLCipher driver conforming to the built-in database/sql interface and using the latest sqlite3 code.
Go to file
Gert-Jan Timmer 6929098dc1 Add: SQLITE_ENABLE_STAT4 2018-05-23 22:21:33 +02:00
_example fix type of event code 2018-01-29 11:15:57 +09:00
tool bump sqlite 3.22.0 2018-02-07 19:47:10 +09:00
.gitignore add *.o 2016-08-11 18:43:49 +09:00
.travis.yml Updated travis.yml 2017-10-22 14:57:02 +03:00
LICENSE Add LICENSE file 2014-08-18 16:52:12 +09:00
README.md README: Update list issues concurrent read/writes 2018-02-24 19:53:12 +00:00
backup.go fix breaking compatibility. 2017-03-21 09:14:48 +09:00
backup_test.go Test the error reporting when preparing to perform a backup. 2016-09-23 08:41:32 -04:00
callback.go Merge branch 'master' into master 2017-08-30 19:57:18 +09:00
callback_test.go Move argument converters to callback.go, and optimize return value handling. 2015-08-21 16:37:45 -07:00
doc.go Removing an unused C import to allow for "buildable" go files. Fixes https://github.com/mattn/go-sqlite3/issues/374 2017-01-18 17:14:12 +01:00
error.go fix breaking compatibility. 2017-03-21 09:14:48 +09:00
error_test.go fix error message 2017-11-19 00:09:25 +09:00
sqlite3-binding.c bump sqlite3 3.23.1 2018-04-17 22:18:20 +09:00
sqlite3-binding.h bump sqlite3 3.23.1 2018-04-17 22:18:20 +09:00
sqlite3.go Merge pull request #540 from mattn/open-mode 2018-04-19 16:32:57 +09:00
sqlite3_context.go rename 2017-03-05 21:40:25 +09:00
sqlite3_go18.go Add static_mock.go to allow building with CGO_ENABLED=0 2018-01-31 22:24:37 -06:00
sqlite3_go18_test.go Fix race in ExecContext 2017-11-21 13:40:00 +01:00
sqlite3_libsqlite3.go support Solaris 2017-08-30 13:19:01 +09:00
sqlite3_load_extension.go disable extension when loading failed 2017-03-21 00:47:07 +09:00
sqlite3_omit_load_extension.go Disable LoadExtension when omit_load_extension is specified 2016-04-18 19:58:56 +08:00
sqlite3_opt_allow_uri_authority.go Add: SQLITE_ALLOW_URI_AUTHORITY 2018-05-23 22:20:35 +02:00
sqlite3_opt_app_armor.go Add: SQLITE_ENABLE_API_ARMOR 2018-05-23 22:20:48 +02:00
sqlite3_opt_foreign_keys.go Add: SQLITE_DEFAULT_FOREIGN_KEYS 2018-05-23 22:21:00 +02:00
sqlite3_opt_fts3_test.go Rename 2018-05-23 22:20:06 +02:00
sqlite3_opt_fts5.go Rename 2018-05-23 22:20:06 +02:00
sqlite3_opt_icu.go Rename 2018-05-23 22:20:06 +02:00
sqlite3_opt_introspect.go Add: SQLITE_INTROSPECTION_PRAGMAS 2018-05-23 22:21:11 +02:00
sqlite3_opt_json1.go Rename 2018-05-23 22:20:06 +02:00
sqlite3_opt_secure_delete.go Add: SQLITE_SECURE_DELETE 2018-05-23 22:21:22 +02:00
sqlite3_opt_stat4.go Add: SQLITE_ENABLE_STAT4 2018-05-23 22:21:33 +02:00
sqlite3_opt_vtable.go Rename 2018-05-23 22:20:06 +02:00
sqlite3_opt_vtable_test.go Rename 2018-05-23 22:20:06 +02:00
sqlite3_other.go support Solaris 2017-08-30 13:19:01 +09:00
sqlite3_solaris.go add build constraint for solaris 2018-01-22 10:29:16 +09:00
sqlite3_test.go Merge pull request #549 from mjtrangoni/fix-linter-issues 2018-04-17 22:17:04 +09:00
sqlite3_trace.go fix type of event code 2018-01-29 11:15:57 +09:00
sqlite3_type.go go vet && golint 2016-11-06 13:16:38 +09:00
sqlite3_windows.go Fix compile for old mingw32 2015-12-30 00:19:24 +02:00
sqlite3ext.h bump sqlite 3.23.0 2018-04-04 22:48:19 +09:00
static_mock.go Add static_mock.go to allow building with CGO_ENABLED=0 2018-01-31 22:24:37 -06:00

README.md

go-sqlite3

GoDoc Reference Build Status Coverage Status Go Report Card

Description

sqlite3 driver conforming to the built-in database/sql interface

Installation

This package can be installed with the go get command:

go get github.com/mattn/go-sqlite3

go-sqlite3 is cgo package. If you want to build your app using go-sqlite3, you need gcc. However, after you have built and installed go-sqlite3 with go install github.com/mattn/go-sqlite3 (which requires gcc), you can build your app without relying on gcc in future.

Documentation

API documentation can be found here: http://godoc.org/github.com/mattn/go-sqlite3

Examples can be found under the ./_example directory

FAQ

  • Want to build go-sqlite3 with libsqlite3 on my linux.

    Use go build --tags "libsqlite3 linux"

  • Want to build go-sqlite3 with libsqlite3 on OS X.

    Install sqlite3 from homebrew: brew install sqlite3

    Use go build --tags "libsqlite3 darwin"

  • Want to build go-sqlite3 with icu extension.

    Use go build --tags "icu"

    Available extensions: json1, fts5, icu

  • Can't build go-sqlite3 on windows 64bit.

    Probably, you are using go 1.0, go1.0 has a problem when it comes to compiling/linking on windows 64bit. See: #27

  • Getting insert error while query is opened.

    You can pass some arguments into the connection string, for example, a URI. See: #39

  • Do you want to cross compile? mingw on Linux or Mac?

    See: #106 See also: http://www.limitlessfx.com/cross-compile-golang-app-for-windows-from-linux.html

  • Want to get time.Time with current locale

    Use _loc=auto in SQLite3 filename schema like file:foo.db?_loc=auto.

  • Can I use this in multiple routines concurrently?

    Yes for readonly. But, No for writable. See #50, #51, #209, #274.

  • Why is it racy if I use a sql.Open("sqlite3", ":memory:") database?

    Each connection to :memory: opens a brand new in-memory sql database, so if the stdlib's sql engine happens to open another connection and you've only specified ":memory:", that connection will see a brand new database. A workaround is to use "file::memory:?mode=memory&cache=shared". Every connection to this string will point to the same in-memory database. See #204 for more info.

License

MIT: http://mattn.mit-license.org/2012

sqlite3-binding.c, sqlite3-binding.h, sqlite3ext.h

The -binding suffix was added to avoid build failures under gccgo.

In this repository, those files are an amalgamation of code that was copied from SQLite3. The license of that code is the same as the license of SQLite3.

Author

Yasuhiro Matsumoto (a.k.a mattn)