mirror of
https://github.com/status-im/status-go.git
synced 2025-01-25 22:19:51 +00:00
87 lines
3.2 KiB
Go
87 lines
3.2 KiB
Go
|
// Copyright (c) 2018 David Crawshaw <david@zentus.com>
|
||
|
// Copyright (c) 2021 Ross Light <ross@zombiezen.com>
|
||
|
//
|
||
|
// Permission to use, copy, modify, and distribute this software for any
|
||
|
// purpose with or without fee is hereby granted, provided that the above
|
||
|
// copyright notice and this permission notice appear in all copies.
|
||
|
//
|
||
|
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||
|
// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||
|
// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||
|
// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||
|
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||
|
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||
|
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||
|
//
|
||
|
// SPDX-License-Identifier: ISC
|
||
|
|
||
|
/*
|
||
|
Package sqlite provides a Go interface to SQLite 3.
|
||
|
|
||
|
The semantics of this package are deliberately close to the
|
||
|
SQLite3 C API, so it is helpful to be familiar with
|
||
|
http://www.sqlite.org/c3ref/intro.html.
|
||
|
|
||
|
An SQLite connection is represented by a *sqlite.Conn.
|
||
|
Connections cannot be used concurrently.
|
||
|
A typical Go program will create a pool of connections
|
||
|
(using Open to create a *sqlitex.Pool) so goroutines can
|
||
|
borrow a connection while they need to talk to the database.
|
||
|
|
||
|
This package assumes SQLite will be used concurrently by the
|
||
|
process through several connections, so the build options for
|
||
|
SQLite enable multi-threading and the shared cache:
|
||
|
https://www.sqlite.org/sharedcache.html
|
||
|
|
||
|
The implementation automatically handles shared cache locking,
|
||
|
see the documentation on Stmt.Step for details.
|
||
|
|
||
|
The optional SQLite 3 extensions compiled in are: session, FTS5, RTree, JSON1,
|
||
|
and GeoPoly.
|
||
|
|
||
|
This is not a database/sql driver. For helper functions that make some kinds of
|
||
|
statements easier to write, see the sqlitex package.
|
||
|
|
||
|
|
||
|
Statement Caching
|
||
|
|
||
|
Statements are prepared with the Prepare and PrepareTransient methods.
|
||
|
When using Prepare, statements are keyed inside a connection by the
|
||
|
original query string used to create them. This means long-running
|
||
|
high-performance code paths can write:
|
||
|
|
||
|
stmt, err := conn.Prepare("SELECT ...")
|
||
|
|
||
|
After all the connections in a pool have been warmed up by passing
|
||
|
through one of these Prepare calls, subsequent calls are simply a
|
||
|
map lookup that returns an existing statement.
|
||
|
|
||
|
|
||
|
Streaming Blobs
|
||
|
|
||
|
The sqlite package supports the SQLite incremental I/O interface for
|
||
|
streaming blob data into and out of the the database without loading
|
||
|
the entire blob into a single []byte.
|
||
|
(This is important when working either with very large blobs, or
|
||
|
more commonly, a large number of moderate-sized blobs concurrently.)
|
||
|
|
||
|
|
||
|
Deadlines and Cancellation
|
||
|
|
||
|
Every connection can have a done channel associated with it using
|
||
|
the SetInterrupt method. This is typically the channel returned by
|
||
|
a context.Context Done method.
|
||
|
|
||
|
As database connections are long-lived, the SetInterrupt method can
|
||
|
be called multiple times to reset the associated lifetime.
|
||
|
|
||
|
|
||
|
Transactions
|
||
|
|
||
|
SQLite transactions have to be managed manually with this package
|
||
|
by directly calling BEGIN / COMMIT / ROLLBACK or
|
||
|
SAVEPOINT / RELEASE/ ROLLBACK. The sqlitex has a Savepoint
|
||
|
function that helps automate this.
|
||
|
*/
|
||
|
package sqlite
|