Documentation
¶
Index ¶
- func ApplyBindings(args ...any) (err error)
- func CreateTestingDatabase(driverName string, baseDataSourceName string, uniqueTestID string) (dsn string, err error)
- func IsLockContentionError(err error) bool
- func Nullify[T comparable](value T) any
- func RegisterVirtualFunc(name string, handler func(driverName string, args string) (string, error))
- type Binder
- type DB
- func (db *DB) Begin() (*Tx, error)
- func (db *DB) BeginTx(ctx context.Context, opts *sql.TxOptions) (*Tx, error)
- func (db *DB) Close() (err error)
- func (db *DB) ConformArgPlaceholders(stmt string) stringdeprecated
- func (db *DB) DriverName() string
- func (db *DB) Exec(query string, args ...any) (sql.Result, error)
- func (db *DB) ExecContext(ctx context.Context, query string, args ...any) (sql.Result, error)
- func (db *DB) InsertReturnID(ctx context.Context, idColumn string, stmt string, args ...any) (int64, error)
- func (db *DB) Migrate(sequenceName string, fileSys fs.FS) (err error)
- func (db *DB) NowUTC() stringdeprecated
- func (db *DB) Prepare(query string) (*sql.Stmt, error)
- func (db *DB) PrepareContext(ctx context.Context, query string) (*sql.Stmt, error)
- func (db *DB) Query(query string, args ...any) (*sql.Rows, error)
- func (db *DB) QueryContext(ctx context.Context, query string, args ...any) (*sql.Rows, error)
- func (db *DB) QueryRow(query string, args ...any) *Row
- func (db *DB) QueryRowContext(ctx context.Context, query string, args ...any) *Row
- func (db *DB) RegexpTextSearch(searchableColumns ...string) stringdeprecated
- func (db *DB) SetLogger(logger *slog.Logger)
- func (db *DB) SetMeterProvider(mp metric.MeterProvider)
- func (db *DB) SetTracerProvider(tp trace.TracerProvider)
- func (db *DB) Transact(ctx context.Context, fn func(tx *Tx) error) (err error)
- func (db *DB) UnpackQuery(query string) (string, error)
- type Executor
- type Null
- type Row
- type Tx
- func (tx *Tx) DriverName() string
- func (tx *Tx) Err() error
- func (tx *Tx) Exec(query string, args ...any) (sql.Result, error)
- func (tx *Tx) ExecContext(ctx context.Context, query string, args ...any) (sql.Result, error)
- func (tx *Tx) InsertReturnID(ctx context.Context, idColumn string, stmt string, args ...any) (int64, error)
- func (tx *Tx) Prepare(query string) (*sql.Stmt, error)
- func (tx *Tx) PrepareContext(ctx context.Context, query string) (*sql.Stmt, error)
- func (tx *Tx) Query(query string, args ...any) (*sql.Rows, error)
- func (tx *Tx) QueryContext(ctx context.Context, query string, args ...any) (*sql.Rows, error)
- func (tx *Tx) QueryRow(query string, args ...any) *Row
- func (tx *Tx) QueryRowContext(ctx context.Context, query string, args ...any) *Row
- func (tx *Tx) UnpackQuery(query string) (string, error)
- type UnsafeSQL
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ApplyBindings ¶
ApplyBindings should be called after scanning values from the result set to perform all late binding.
func CreateTestingDatabase ¶ added in v1.6.1
func CreateTestingDatabase(driverName string, baseDataSourceName string, uniqueTestID string) (dsn string, err error)
CreateTestingDatabase provisions a uniquely-named database (or returns a SQLite in-memory DSN) for testing and returns the resolved data source name. Pass the result to Open or OpenSingleton to open a connection.
The returned DSN points at a database whose name has the testing_NN_ prefix. When the last *DB referencing that database is Closed, sequel drops it automatically — no separate cleanup call is required.
uniqueTestID scopes the database so that independent tests don't collide. Pass t.Name() from a test, or an equivalent identifier from production startup code that wants a per-run database:
dsn := cfg.DSN
if cfg.Testing {
dsn, err = sequel.CreateTestingDatabase("", cfg.DSN, cfg.TestID)
if err != nil { return err }
}
db, err := sequel.OpenSingleton("", dsn)
Within a single process, repeated calls with the same (driverName, baseDataSourceName, uniqueTestID) reuse the same testing database — the underlying DROP+CREATE only happens on the first call.
If a driver name is not provided, it is inferred from the data source name on a best-effort basis. Drivers currently supported: "mysql" (MySQL), "pgx" (Postgres), "cockroachdb" (CockroachDB), "mssql" (SQL Server) or "sqlite" (SQLite).
If neither a driver name nor a base data source name is provided, it falls back to the SEQUEL_TESTING_DSN environment variable. This lets any consumer that builds ephemeral test databases through sequel redirect its entire suite at a real server without changing test code: leave SEQUEL_TESTING_DSN unset to keep the SQLite default, or set it to a base DSN to run against that server instead, with the driver inferred from it. Naming a driver — even with an empty DSN — opts out of the fallback, so a test that explicitly asks for SQLite keeps running on SQLite regardless of the environment.
If neither the arguments nor SEQUEL_TESTING_DSN select a server, the following localhost defaults are used based on the driver name:
- (empty): SQLite in-memory database
- sqlite: SQLite in-memory database
- mysql: root:root@tcp(127.0.0.1:3306)/
- pgx: postgres://postgres:postgres@127.0.0.1:5432/
- cockroachdb: postgres://root@127.0.0.1:26257/?sslmode=disable
- mssql: sqlserver://sa:Password123@127.0.0.1:1433
func IsLockContentionError ¶ added in v1.5.7
IsLockContentionError returns true if the error indicates database lock contention or a deadlock. Such errors are transient and the operation can typically be retried. Recognizes lock errors from SQLite, MySQL, PostgreSQL, SQL Server, and CockroachDB.
Classification prefers the driver's native error code (immune to message wording, localization, and user data appearing in error messages); a substring match is used as a fallback for errors whose driver type is not present in the chain (e.g. some wrapped or text-only CockroachDB retry errors).
func Nullify ¶
func Nullify[T comparable](value T) any
Nullify returns nil if the value equals to the zero value of its Go data type, else it returns the value. Use this construct to convert zero values to nil when writing to a nullable database column.
Example:
db.Exec( "INSERT INTO my_table (id, desc, modified_time) VALUES (?,?,?)", obj.ID, sequel.Nullify(obj.Description), sequel.Nullify(obj.ModifiedTime), )
func RegisterVirtualFunc ¶ added in v1.2.0
RegisterVirtualFunc registers a virtual SQL function that will be replaced in queries before execution. The name is matched case-insensitively, e.g. registering "NOW_UTC" matches NOW_UTC(), now_utc(), Now_Utc(), etc. The handler receives the driver name and the string found between the parentheses, and returns the replacement SQL expression, or an error.
Types ¶
type Binder ¶
Binder is a thin wrapper over sql.Null that allows for late-binding of its value.
func Bind ¶
Bind applies a binding function to the scanned value.
Example:
var obj Object
args := []any{
&obj.ID,
sequel.Bind(func(tags string) {
return json.Unmarshal([]byte(tags), &obj.Tags)
}),
sequel.Bind(func(modifiedTime time.Time) {
obj.Year, obj.Month, obj.Day = modifiedTime.Date()
return nil
}),
}
db.QueryRow("SELECT id, tags, modified_time FROM my_table WHERE id=?", id).Scan(args...)
sequel.ApplyBindings(args...)
type DB ¶
DB is an enhanced database connection that
- Limits the size of the connection pool to each server to approx the sqrt of the number of clients
- Performs schema migration
- Automatically creates and connects to a localhost database while testing
func Open ¶
Open returns a database connection to the named data source with a dedicated connection pool. Each call returns a distinct *DB; sequel does not coalesce by DSN. The caller is responsible for sizing the pool via SetMaxOpenConns / SetMaxIdleConns if the database/sql defaults (unlimited open, 2 idle) don't fit.
Use OpenSingleton when multiple consumers in the same process share a DSN and you want sequel to manage one pool across all of them.
If a driver name is not provided, it is inferred from the data source name on a best-effort basis. Drivers currently supported: "mysql" (MySQL), "pgx" (Postgres), "cockroachdb" (CockroachDB), "mssql" (SQL Server) or "sqlite" (SQLite).
Example data source name for each of the supported drivers:
- mysql: username:password@tcp(hostname:3306)/
- pgx: postgres://username:password@hostname:5432/
- cockroachdb: postgres://username:password@hostname:26257/
- mssql: sqlserver://username:password@hostname:1433
- sqlite: file:path/to/database.sqlite
func OpenSingleton ¶ added in v1.6.1
OpenSingleton returns a per-DSN coalesced *DB whose connection pool sequel manages automatically based on the number of openers (sqrt-based growth, see [DB.adjustConnectionLimits]). Multiple OpenSingleton calls with the same (driverName, dataSourceName) return the same *DB and share its connection pool. This is the right choice when many parts of the same process each access the database occasionally.
Use Open when you want a dedicated pool with explicit caller-managed sizing.
Driver inference, DSN defaults, and supported drivers are the same as Open.
func (*DB) Begin ¶ added in v1.4.0
Begin starts a transaction and returns a sequel.Tx that applies virtual function expansion and placeholder conforming.
func (*DB) BeginTx ¶ added in v1.4.0
BeginTx starts a transaction with the given options and returns a sequel.Tx that applies virtual function expansion and placeholder conforming.
func (*DB) Close ¶
Close closes the database connection.
When the last reference closes and the underlying database name matches the testing pattern (testing_NN_…), sequel drops the database from the server as a best-effort cleanup. This makes CreateTestingDatabase-provisioned databases self-cleaning on test teardown.
func (*DB) ConformArgPlaceholders
deprecated
func (*DB) DriverName ¶
DriverName is the name of the driver: "mysql", "pgx", "cockroachdb", "mssql" or "sqlite".
func (*DB) Exec ¶ added in v1.2.0
Exec shadows sql.DB.Exec and conforms arg placeholders for the driver.
func (*DB) ExecContext ¶ added in v1.2.0
ExecContext shadows sql.DB.ExecContext and conforms arg placeholders for the driver.
func (*DB) InsertReturnID ¶ added in v1.3.0
func (db *DB) InsertReturnID(ctx context.Context, idColumn string, stmt string, args ...any) (int64, error)
InsertReturnID executes an INSERT statement and returns the auto-generated ID for the named ID column.
func (*DB) Migrate ¶
Migrate reads all #.sql files from the FS, and executes any new migrations in order of their file name. The order of execution is guaranteed only within the context of a sequence name.
func (*DB) Prepare ¶ added in v1.2.0
Prepare shadows sql.DB.Prepare and conforms arg placeholders for the driver.
func (*DB) PrepareContext ¶ added in v1.2.0
PrepareContext shadows sql.DB.PrepareContext and conforms arg placeholders for the driver.
func (*DB) Query ¶ added in v1.2.0
Query shadows sql.DB.Query and conforms arg placeholders for the driver.
func (*DB) QueryContext ¶ added in v1.2.0
QueryContext shadows sql.DB.QueryContext and conforms arg placeholders for the driver.
func (*DB) QueryRow ¶ added in v1.2.0
QueryRow shadows sql.DB.QueryRow and conforms arg placeholders for the driver. It returns a Row, which embeds *sql.Row so existing QueryRow(...).Scan(...) call sites are unchanged.
func (*DB) QueryRowContext ¶ added in v1.2.0
QueryRowContext shadows sql.DB.QueryRowContext and conforms arg placeholders for the driver. It returns a Row, which embeds *sql.Row so existing QueryRowContext(...).Scan(...) call sites are unchanged.
func (*DB) RegexpTextSearch
deprecated
func (*DB) SetLogger ¶ added in v1.9.0
SetLogger attaches an slog.Logger. The library does not log operation errors (they are returned to the caller, who logs them); it logs one-off events such as schema migrations at Info, and — when the logger is enabled at Debug level — each query at Debug. Per-query logging is therefore controlled by the logger's own level, not a separate switch. A freshly opened *DB uses a discard logger; pass nil here to revert to that discard logger (disabling logging).
func (*DB) SetMeterProvider ¶ added in v1.9.0
func (db *DB) SetMeterProvider(mp metric.MeterProvider)
SetMeterProvider attaches an OpenTelemetry MeterProvider so sequel emits sequel_ metrics (query and transaction duration, lock-contention count, migration count, and connection-pool gauges). A freshly opened *DB already uses the process-wide otel.GetMeterProvider(); call this to override it, or pass nil to revert to that global provider (whose default is a no-op). See DB.SetTracerProvider for when to call.
func (*DB) SetTracerProvider ¶ added in v1.9.0
func (db *DB) SetTracerProvider(tp trace.TracerProvider)
SetTracerProvider attaches an OpenTelemetry TracerProvider so sequel emits a client span around each query, transaction, and migration. A freshly opened *DB already uses the process-wide otel.GetTracerProvider(); call this to override it, or pass nil to revert to that global provider (whose default is a no-op).
Observability is configured after Open/OpenSingleton (which keep the standard database/sql signature) rather than at construction. This loses nothing: sql.Open does no I/O — it only prepares a lazy pool — so there is no work inside Open worth a span; every operation that does real work happens later on the returned *DB.
Configure before the *DB is used concurrently. For an OpenSingleton-shared *DB the providers are process- wide for that pool; the last setter wins, so configure once from the owning caller.
func (*DB) Transact ¶ added in v1.8.0
Transact runs fn inside a transaction, committing on success and rolling back on error. If the transaction fails on lock contention or a deadlock, it is retried with a short jittered backoff. Because a retry re-executes fn from the start in a new transaction, fn must be safe to run more than once; any non-transactional side effects it performs (in-memory changes, channel sends) may repeat.
The Tx passed to fn records the first statement error and short-circuits the remaining statements, so fn cannot commit partial work even if it does not check every statement's error. For SQL Server, SET XACT_ABORT ON is applied so that any statement error aborts the whole transaction.
func (*DB) UnpackQuery ¶ added in v1.2.0
UnpackQuery expands virtual functions (e.g. NOW_UTC(), REGEXP_TEXT_SEARCH()) into driver-specific SQL expressions, and conforms arg placeholders to the syntax expected by the driver (e.g. ? to $1, $2 for PostgreSQL).
type Executor ¶ added in v1.4.1
type Executor interface {
Exec(query string, args ...any) (sql.Result, error)
ExecContext(ctx context.Context, query string, args ...any) (sql.Result, error)
Query(query string, args ...any) (*sql.Rows, error)
QueryContext(ctx context.Context, query string, args ...any) (*sql.Rows, error)
QueryRow(query string, args ...any) *Row
QueryRowContext(ctx context.Context, query string, args ...any) *Row
Prepare(query string) (*sql.Stmt, error)
PrepareContext(ctx context.Context, query string) (*sql.Stmt, error)
InsertReturnID(ctx context.Context, idColumn string, stmt string, args ...any) (int64, error)
DriverName() string
UnpackQuery(query string) (string, error)
}
Executor is the interface satisfied by both DB and Tx.
type Null ¶
Null is a thin wrapper over sql.Null that allows for reading NULL values.
func Nullable ¶
Nullable is a simple binder that interprets NULL values to be the zero value of their Go data type.
Example:
var obj Object
args := []any{
&obj.ID,
sequel.Nullable(&obj.Description),
sequel.Nullable(&obj.ModifiedTime),
}
db.QueryRow("SELECT id, desc, modified_time FROM my_table WHERE id=?", id).Scan(args...)
sequel.ApplyBindings(args...)
type Row ¶ added in v1.9.0
Row shadows *sql.Row so sequel can observe a single-row query. database/sql does not surface a QueryRow error until Scan, so Row records the operation's duration, classifies lock contention, and ends the span when the caller calls Scan (or Err). It embeds *sql.Row, so the common QueryRow(...).Scan(...) call site is unchanged; only code that explicitly stores the result as *sql.Row needs adjustment.
As with *sql.Row, a Row whose Scan/Err is never called holds resources open — and here, leaves its span unended. Call Scan (or Err) exactly as you would with *sql.Row.
type Tx ¶ added in v1.4.0
Tx is an in-progress database transaction that shadows sql.Tx methods to apply virtual function expansion and placeholder conforming.
When created by DB.Transact, a Tx records the first statement error and short-circuits subsequent statements (returning that error without touching the database). This guarantees a transaction cannot commit partial state when a caller forgets to check a statement's error, and it surfaces a deadlock (rather than masking it as a later "COMMIT has no corresponding BEGIN" on some drivers) so Transact can retry. A Tx obtained from DB.BeginTx does not do this — its statement methods behave exactly like the underlying sql.Tx.
func (*Tx) DriverName ¶ added in v1.4.0
DriverName is the name of the driver: "mysql", "pgx", "cockroachdb", "mssql" or "sqlite".
func (*Tx) Err ¶ added in v1.8.0
Err returns the first statement error recorded in Transact mode, or nil. Always nil for a Tx obtained from BeginTx.
func (*Tx) Exec ¶ added in v1.4.0
Exec shadows sql.Tx.Exec and conforms arg placeholders for the driver.
func (*Tx) ExecContext ¶ added in v1.4.0
ExecContext shadows sql.Tx.ExecContext and conforms arg placeholders for the driver.
func (*Tx) InsertReturnID ¶ added in v1.4.0
func (tx *Tx) InsertReturnID(ctx context.Context, idColumn string, stmt string, args ...any) (int64, error)
InsertReturnID executes an INSERT statement and returns the auto-generated ID for the named ID column.
func (*Tx) Prepare ¶ added in v1.4.0
Prepare shadows sql.Tx.Prepare and conforms arg placeholders for the driver.
func (*Tx) PrepareContext ¶ added in v1.4.0
PrepareContext shadows sql.Tx.PrepareContext and conforms arg placeholders for the driver.
func (*Tx) Query ¶ added in v1.4.0
Query shadows sql.Tx.Query and conforms arg placeholders for the driver.
func (*Tx) QueryContext ¶ added in v1.4.0
QueryContext shadows sql.Tx.QueryContext and conforms arg placeholders for the driver.
func (*Tx) QueryRow ¶ added in v1.4.0
QueryRow shadows sql.Tx.QueryRow and conforms arg placeholders for the driver. It returns a Row, which embeds *sql.Row so existing QueryRow(...).Scan(...) call sites are unchanged.
func (*Tx) QueryRowContext ¶ added in v1.4.0
QueryRowContext shadows sql.Tx.QueryRowContext and conforms arg placeholders for the driver. It returns a Row, which embeds *sql.Row so existing QueryRowContext(...).Scan(...) call sites are unchanged.
func (*Tx) UnpackQuery ¶ added in v1.4.0
UnpackQuery expands virtual functions (e.g. NOW_UTC(), REGEXP_TEXT_SEARCH()) into driver-specific SQL expressions, and conforms arg placeholders to the syntax expected by the driver (e.g. ? to $1, $2 for PostgreSQL).