diff options
author | mattn <mattn.jp@gmail.com> | 2013-08-28 14:50:02 +0900 |
---|---|---|
committer | mattn <mattn.jp@gmail.com> | 2013-08-28 14:50:02 +0900 |
commit | 501b1ea772a8ad6a5126ab5a1307da4b3e613ade (patch) | |
tree | 98605d164a415dd14ef632cae1c112c59d71a893 /_example | |
parent | Use sqlite3.c in all platforms (diff) | |
download | golite-501b1ea772a8ad6a5126ab5a1307da4b3e613ade.tar.gz golite-501b1ea772a8ad6a5126ab5a1307da4b3e613ade.tar.xz |
mv
Diffstat (limited to '_example')
-rw-r--r-- | _example/extension/extension.go | 43 | ||||
-rw-r--r-- | _example/extension/sqlite3_mod_regexp.c | 31 | ||||
-rw-r--r-- | _example/simple/simple.go | 95 |
3 files changed, 169 insertions, 0 deletions
diff --git a/_example/extension/extension.go b/_example/extension/extension.go new file mode 100644 index 0000000..61ceb55 --- /dev/null +++ b/_example/extension/extension.go @@ -0,0 +1,43 @@ +package main + +import ( + "database/sql" + "fmt" + "github.com/mattn/go-sqlite3" + "log" +) + +func main() { + sql.Register("sqlite3_with_extensions", + &sqlite3.SQLiteDriver{ + Extensions: []string{ + "sqlite3_mod_regexp", + }, + }) + + db, err := sql.Open("sqlite3_with_extensions", ":memory:") + if err != nil { + log.Fatal(err) + } + defer db.Close() + + // Force db to make a new connection in pool + // by putting the original in a transaction + tx, err := db.Begin() + if err != nil { + log.Fatal(err) + } + defer tx.Commit() + + // New connection works (hopefully!) + rows, err := db.Query("select 'hello world' where 'hello world' regexp '^hello.*d$'") + if err != nil { + log.Fatal(err) + } + defer rows.Close() + for rows.Next() { + var helloworld string + rows.Scan(&helloworld) + fmt.Println(helloworld) + } +} diff --git a/_example/extension/sqlite3_mod_regexp.c b/_example/extension/sqlite3_mod_regexp.c new file mode 100644 index 0000000..277764d --- /dev/null +++ b/_example/extension/sqlite3_mod_regexp.c @@ -0,0 +1,31 @@ +#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); +} diff --git a/_example/simple/simple.go b/_example/simple/simple.go new file mode 100644 index 0000000..5e9c902 --- /dev/null +++ b/_example/simple/simple.go @@ -0,0 +1,95 @@ +package main + +import ( + "database/sql" + "fmt" + _ "github.com/mattn/go-sqlite3" + "log" + "os" +) + +func main() { + os.Remove("./foo.db") + + db, err := sql.Open("sqlite3", "./foo.db") + if err != nil { + log.Fatal(err) + } + defer db.Close() + + sqls := []string{ + "create table foo (id integer not null primary key, name text)", + "delete from foo", + } + for _, sql := range sqls { + _, err = db.Exec(sql) + if err != nil { + log.Printf("%q: %s\n", err, sql) + return + } + } + + tx, err := db.Begin() + if err != nil { + log.Fatal(err) + } + stmt, err := tx.Prepare("insert into foo(id, name) values(?, ?)") + if err != nil { + log.Fatal(err) + } + defer stmt.Close() + for i := 0; i < 100; i++ { + _, err = stmt.Exec(i, fmt.Sprintf("こんにちわ世界%03d", i)) + if err != nil { + log.Fatal(err) + } + } + tx.Commit() + + rows, err := db.Query("select id, name from foo") + if err != nil { + log.Fatal(err) + } + defer rows.Close() + for rows.Next() { + var id int + var name string + rows.Scan(&id, &name) + fmt.Println(id, name) + } + rows.Close() + + stmt, err = db.Prepare("select name from foo where id = ?") + if err != nil { + log.Fatal(err) + } + defer stmt.Close() + var name string + err = stmt.QueryRow("3").Scan(&name) + if err != nil { + log.Fatal(err) + } + fmt.Println(name) + + _, err = db.Exec("delete from foo") + if err != nil { + log.Fatal(err) + } + + _, err = db.Exec("insert into foo(id, name) values(1, 'foo'), (2, 'bar'), (3, 'baz')") + if err != nil { + log.Fatal(err) + } + + rows, err = db.Query("select id, name from foo") + if err != nil { + log.Fatal(err) + } + defer rows.Close() + for rows.Next() { + var id int + var name string + rows.Scan(&id, &name) + fmt.Println(id, name) + } +} |