|  | /* | 
|  | Package sqlite3 provides interface to SQLite3 databases. | 
|  |  | 
|  | This works as a driver for database/sql. | 
|  |  | 
|  | Installation | 
|  |  | 
|  | go get github.com/mattn/go-sqlite3 | 
|  |  | 
|  | Supported Types | 
|  |  | 
|  | Currently, go-sqlite3 supports the following data types. | 
|  |  | 
|  | +------------------------------+ | 
|  | |go        | sqlite3           | | 
|  | |----------|-------------------| | 
|  | |nil       | null              | | 
|  | |int       | integer           | | 
|  | |int64     | integer           | | 
|  | |float64   | float             | | 
|  | |bool      | integer           | | 
|  | |[]byte    | blob              | | 
|  | |string    | text              | | 
|  | |time.Time | timestamp/datetime| | 
|  | +------------------------------+ | 
|  |  | 
|  | SQLite3 Extension | 
|  |  | 
|  | You can write your own extension module for sqlite3. For example, below is an | 
|  | extension for a Regexp matcher operation. | 
|  |  | 
|  | #include <pcre.h> | 
|  | #include <string.h> | 
|  | #include <stdio.h> | 
|  | #include <sqlite3ext.h> | 
|  |  | 
|  | SQLITE_EXTENSION_INIT1 | 
|  | static void regexp_func(sqlite3_context *context, int argc, sqlite3_value **argv) { | 
|  | if (argc >= 2) { | 
|  | const char *target  = (const char *)sqlite3_value_text(argv[1]); | 
|  | const char *pattern = (const char *)sqlite3_value_text(argv[0]); | 
|  | const char* errstr = NULL; | 
|  | int erroff = 0; | 
|  | int vec[500]; | 
|  | int n, rc; | 
|  | pcre* re = pcre_compile(pattern, 0, &errstr, &erroff, NULL); | 
|  | rc = pcre_exec(re, NULL, target, strlen(target), 0, 0, vec, 500); | 
|  | if (rc <= 0) { | 
|  | sqlite3_result_error(context, errstr, 0); | 
|  | return; | 
|  | } | 
|  | sqlite3_result_int(context, 1); | 
|  | } | 
|  | } | 
|  |  | 
|  | #ifdef _WIN32 | 
|  | __declspec(dllexport) | 
|  | #endif | 
|  | int sqlite3_extension_init(sqlite3 *db, char **errmsg, | 
|  | const sqlite3_api_routines *api) { | 
|  | SQLITE_EXTENSION_INIT2(api); | 
|  | return sqlite3_create_function(db, "regexp", 2, SQLITE_UTF8, | 
|  | (void*)db, regexp_func, NULL, NULL); | 
|  | } | 
|  |  | 
|  | It needs to be built as a so/dll shared library. And you need to register | 
|  | the extension module like below. | 
|  |  | 
|  | sql.Register("sqlite3_with_extensions", | 
|  | &sqlite3.SQLiteDriver{ | 
|  | Extensions: []string{ | 
|  | "sqlite3_mod_regexp", | 
|  | }, | 
|  | }) | 
|  |  | 
|  | Then, you can use this extension. | 
|  |  | 
|  | rows, err := db.Query("select text from mytable where name regexp '^golang'") | 
|  |  | 
|  | Connection Hook | 
|  |  | 
|  | You can hook and inject your code when the connection is established. database/sql | 
|  | doesn't provide a way to get native go-sqlite3 interfaces. So if you want, | 
|  | you need to set ConnectHook and get the SQLiteConn. | 
|  |  | 
|  | sql.Register("sqlite3_with_hook_example", | 
|  | &sqlite3.SQLiteDriver{ | 
|  | ConnectHook: func(conn *sqlite3.SQLiteConn) error { | 
|  | sqlite3conn = append(sqlite3conn, conn) | 
|  | return nil | 
|  | }, | 
|  | }) | 
|  |  | 
|  | Go SQlite3 Extensions | 
|  |  | 
|  | If you want to register Go functions as SQLite extension functions, | 
|  | call RegisterFunction from ConnectHook. | 
|  |  | 
|  | regex = func(re, s string) (bool, error) { | 
|  | return regexp.MatchString(re, s) | 
|  | } | 
|  | sql.Register("sqlite3_with_go_func", | 
|  | &sqlite3.SQLiteDriver{ | 
|  | ConnectHook: func(conn *sqlite3.SQLiteConn) error { | 
|  | return conn.RegisterFunc("regexp", regex, true) | 
|  | }, | 
|  | }) | 
|  |  | 
|  | See the documentation of RegisterFunc for more details. | 
|  |  | 
|  | */ | 
|  | package sqlite3 | 
|  |  | 
|  | import "C" |