sqlite3 driver for go using database/sql
Go to file
Graeme Connell 341bfcf7f1 Fix example import to point to mattn repo. 2016-11-11 09:50:05 -07:00
_example Fix example import to point to mattn repo. 2016-11-11 09:50:05 -07:00
sqlite3_test Merge branch 'pr/207' 2015-11-02 11:53:42 +09:00
tool upgrade: add ifdefines 2016-10-28 10:28:19 +02:00
.gitignore add *.o 2016-08-11 18:43:49 +09:00
.travis.yml disable combination of libsqlite3 and trace because travis(trusty) is too old. 2016-11-08 18:27:48 +09:00
LICENSE Add LICENSE file 2014-08-18 16:52:12 +09:00
README.md FAQ about concurrency. Close #350 2016-11-07 16:16:17 +09:00
backup.go go vet && golint 2016-11-05 00:40:06 +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 fix trace callback. 2016-11-08 12:19:51 +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 Make Go 1.7 fail compilation 2016-09-03 20:02:56 +01:00
error.go go vet && golint 2016-11-05 00:46:04 +09:00
error_test.go Add test for ErrNo.Extend() 2015-01-26 18:38:13 +09:00
sqlite3-binding.c upgrade amalgamation code 2016-11-11 09:01:23 +09:00
sqlite3-binding.h upgrade amalgamation code 2016-11-11 09:01:23 +09:00
sqlite3.go use prepare instead of Prepare 2016-11-09 01:13:34 +09:00
sqlite3_fts3_test.go FTS4 is not available on Trusty 2016-04-23 00:00:49 +08:00
sqlite3_fts5.go Conditional build for the FTS5 Extension 2016-03-07 16:20:02 +09:00
sqlite3_go18.go go vet && golint 2016-11-06 13:16:38 +09:00
sqlite3_go18_test.go revert Multiple Result Set 2016-11-08 13:22:46 +09:00
sqlite3_icu.go remove trailing space 2016-11-05 00:28:43 +09:00
sqlite3_json1.go Conditional build for the JSON1 Extension 2016-02-28 09:53:54 +01:00
sqlite3_libsqlite3.go Disable LoadExtension when omit_load_extension is specified 2016-04-18 20:21:32 +08:00
sqlite3_load_extension.go go vet && golint 2016-11-05 00:40:06 +09:00
sqlite3_omit_load_extension.go Disable LoadExtension when omit_load_extension is specified 2016-04-18 19:58:56 +08:00
sqlite3_other.go remove -lpthread. related issue #201 2015-04-28 08:58:25 +09:00
sqlite3_test.go go vet && golint 2016-11-06 13:16:38 +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 upgrade amalgamation code 2016-11-11 09:01:23 +09:00
tracecallback.go fix build 2016-11-08 17:24:01 +09:00
tracecallback_noimpl.go go vet && golint 2016-11-05 00:40:06 +09:00

README.md

go-sqlite3

Build Status Coverage Status GoDoc

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, if you install go-sqlite3 with go install github.com/mattn/go-sqlite3, you don't need gcc to build your app anymore.

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"

  • 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: https://github.com/mattn/go-sqlite3/issues/27

  • Getting insert error while query is opened.

    You can pass some arguments into the connection string, for example, a URI. See: https://github.com/mattn/go-sqlite3/issues/39

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

    See: https://github.com/mattn/go-sqlite3/issues/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 use this in multiple routines concurrently?

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

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)