sqlite package provides a low-level interface that allows you to build sqlite extensions that can be loaded dynamically at runtime
or linked statically at build-time (experimental)
This package can be installed with go get as:
$ go get -u go.riyazali.net/sqlitesqlite is a cgo package and requires a working c compiler.
To build an sqlite extension, you need to build your project with -buildmode=c-shared. That would emit
a .so file (or .dll on windows), which you can then load into sqlite.
Consider as an example, the sample upper module in _examples/. To build it, you'd use something similar to:
$ go build -buildmode=c-shared -o upper.so _examples/upperwhich would emit an upper.so in the current directory. Now, to use it with (say) the sqlite3 shell, you could do something like
$ sqlite3
> .load upper.so
> SELECT upper("sqlite3");
SQLITE3
> .exit-
commit/rollbackhooks - custom
collation - custom
scalar,aggregateandwindowfunctions - custom
virtual tabledoes not supportxShadowNameand nested transations yet
Each of the support feature provides an exported interface that the user code must implement. Refer to code and godoc for more details.
MIT License Copyright (c) 2020 Riyaz Ali
Refer to LICENSE for full text.