0
0
mirror of https://github.com/mattn/go-sqlite3.git synced 2025-06-04 01:10:35 +00:00

935 Commits

Author SHA1 Message Date
bc6241221c retab 2022-05-28 23:25:14 +09:00
2cd93c9677 retab 2022-05-28 23:24:03 +09:00
5131ffb8eb add _example/json 2022-05-28 23:21:23 +09:00
43dcd3131f Update _example/simple/Dockerfile 2022-05-18 11:53:00 +09:00
c122302862 feat: simple example of Dockerfile w/ multi-stage build 2022-05-18 11:53:00 +09:00
aa1e904220 Update amalgamation code v1.14.13 2022-05-13 11:15:23 +09:00
adb060d295 Update .github/workflows/go.yaml 2022-05-13 10:44:42 +09:00
a68a2b7fc5 Update supported Golang version to Go 1.18 2022-05-13 10:44:42 +09:00
bedc2985ef Update sqlite3_opt_preupdate_omit.go 2022-04-23 14:23:00 +09:00
c1379fcb35 Update sqlite3_opt_preupdate_hook.go 2022-04-23 14:23:00 +09:00
2df077b74c Update amalgamation v1.14.12 2022-02-28 09:00:54 +09:00
ae2a61f847 Add sqlite3_file_control() support
This commit adds the SQLiteConn.FileControlInt() method which calls the
underlying sqlite3_file_control() function with an int argument. This can
be used for low-level operations on SQLite databases such as persisting
the WAL file after database close.
v1.14.11
2022-01-29 01:58:27 +09:00
671e666c2e Add example using driverName 2022-01-10 23:30:33 +09:00
c0fa5ea6d6 Add driverName to be possible change driver name 2022-01-10 23:30:33 +09:00
98c52198ca Temporary disable test for dropping vtable v1.14.10 2021-12-29 22:26:06 +09:00
7fbc50c941 Update amalgamation code 2021-12-29 22:26:06 +09:00
85436841b3 Fix GitHub workflows 2021-10-26 10:18:49 +09:00
4761e9cad1 Do no test with go-acc on Windows ()
Currently, no way to fix failing
2021-10-26 10:18:18 +09:00
48c6a56ee0 Add go.mod and go.sum for upgrade ()
* Add go.mod and go.sum for upgrade

* Fix upgrade tools to have to run on upgrade directory
2021-10-26 09:39:02 +09:00
bb15a32a4f Drop old versions () 2021-10-26 09:38:41 +09:00
9537be5eb3 Adds CIFuzz for fuzzing as continuous integration () 2021-10-26 00:32:35 +09:00
a4fc68a6cb sqlite3_test.go: Fix go test -run=...: Use standard sub-tests ()
Selecting only some tests with go test -run=... does not work, because
some of the tests are executed using testing.RunTests(). That function
is documented as "an internal function". This changes TestSuite to use
the testing subtests feature instead.

This has a behaviour change: the benchmarks now need to be
selected at the command line with the standard go test -bench=.
flag. This will also set up the test database twice when running
benchmarks, rather than once.
2021-10-26 00:24:46 +09:00
2b131e01c1 change angle bracket import to quotes () 2021-10-26 00:23:19 +09:00
5671e01493 Update SQLite3_ The columntypescantype method of type ()
* sqlite3_type update

The main reason for this change is that the original reflected values are nil. I found that there was no good mapping when dealing with the code here

* Update sqlite3_type.go

Update 'ColumnTypeScanType' method,
Different types of mapping values

* Restore copyright

* Update go.mod

* Update go.mod
2021-10-26 00:19:41 +09:00
2b780b4a7f fix idxStr freeing issue ()
uses snippet suggested by @rittneje https://github.com/mattn/go-sqlite3/issues/897#issuecomment-752162125
2021-10-26 00:13:24 +09:00
98d34f9dc5 Use single-quotes around string literals. () 2021-10-26 00:09:24 +09:00
3bb6941859 sqlite3.go: use PRAGMA to set busy_timeout ()
The busy_timeout pragma was added in sqlite 3.7.15 as an alternative
to calling sqlite3_busy_timeout directly:

https://sqlite.org/pragma.html#pragma_busy_timeout

While there's no functional change here, using the pragma does align
setting busy_timeout with other settings and removes the special case
for calling sqlite3_busy_timeout directly.
2021-10-26 00:08:40 +09:00
ab653675c9 Test on 1.17 2021-10-26 00:06:23 +09:00
1cdbb70da1 run tests against Go 1.16 () 2021-10-26 00:05:59 +09:00
b3df4a5ff0 Fix typo in README.md ()
seperated -> separated
2021-10-26 00:05:45 +09:00
4bc7a1fc15 Resolve windows CI issues ()
Do not use `-u` flag when fetching go-acc
2021-10-26 00:05:01 +09:00
1f85ebd7c4 Allow building on OpenBSD () 2021-10-26 00:02:17 +09:00
628398eed2 chore: readme: Fix link, typos, copy editing ()
* chore: readme: Fix link, typos, copy editing

Also closes , .

* Update README.md
2021-10-22 16:35:44 +09:00
3900dc3187 return non-nil result when calling exec with empty query ()
fixes 
2021-10-19 18:18:21 +09:00
3392062c72 bump codecov/codecov-action@v2 () v1.14.9 2021-07-20 22:28:26 +09:00
cba6eaee48 Update amalgamation code ()
* Update amalgamation code

* Apply realPy's patch
v1.14.8
2021-07-15 22:31:14 +09:00
1157a4212d Update amalgamation code () 2021-04-15 00:44:23 +09:00
ab91e9342b make column metadata functionality opt-in 2021-02-18 13:34:41 -05:00
95e88ca693 Export sqlite3_column_table_name () 2021-02-18 11:58:21 +09:00
323de98a4c Go get go-acc with environment variable for go modules ()
* Go get go-acc with environment variable for go modules

* Go get with modules for windows as well
2021-02-16 22:01:58 +09:00
16175c1389 Adds a fuzz target ()
* Adds a fuzz target

* Fixes memory leak
2021-02-15 22:57:26 +09:00
3cbdae750e Export sqlite3_stmt_readonly() via SQLiteStmt.Readonly() ()
This can be used like in the test; I wrote a little wrapper around
sql.DB which uses this, and allows concurrent reads but just one single
write. This is perhaps a better generic "table locked"-solution than
setting the connections to 1 and/or cache=shared (although even better
would be to design your app in such a way that this doesn't happpen in
the first place, but even then a little seat belt isn't a bad thing).

The parsing adds about 0.1ms to 0.2ms of overhead in the wrapper, which
isn't too bad (and it caches the results, so only needs to do this
once).

At any rate, I can't really access functions from sqlite3-binding.c from
my application, so expose it via SQLiteStmt.
2020-12-28 08:52:08 +09:00
52436d4074 Update amalgamation code () v1.14.6 2020-12-26 23:18:41 +09:00
92d23714a8 add support for defining an "eponymous only" virtual table ()
* add support for defining an "eponymous only" virtual table

As suggested here: https://github.com/mattn/go-sqlite3/issues/846#issuecomment-736206222

* add an example of an eponymous only vtab module

* add a test case for an eponymous only vtab module
2020-12-26 23:11:17 +09:00
66ff625f34 RowsColumnTypeNullable not implemented () 2020-12-26 23:07:28 +09:00
02ce7ec581 Add ?_cache_size=[..] to connection parameters ()
Add a shortcut for PRAGMA cache_size; this is a pretty useful setting:
the default of -2000 (2M) is not especially high, and a lot of people
will probably want to increase this.

For example, while running a bunch of fairy expensive queries in
parallel:

	With SetMaxOpenConns(1):
	 -2000:  5762ms
	-20000:  4714ms

	With SetMaxOpenConns(20):
	 -2000:  3067ms
	-20000:  2532ms

Which isn't a bad performance boost for changing a single number.
2020-12-26 23:05:20 +09:00
e30206cd31 clarify usleep license () 2020-12-26 23:04:03 +09:00
223d277c80 Fix ci 2020-11-18 00:34:04 +09:00
ae4208e73a Drop go1.11 ()
* Drop go1.11

* Use go1.12
2020-11-17 10:04:27 +09:00
0709612629 README.md: use link in markdown () 2020-11-17 10:04:13 +09:00