58 lines
1.2 KiB
Go
58 lines
1.2 KiB
Go
package dbimpl
|
|
|
|
import (
|
|
"context"
|
|
"database/sql"
|
|
|
|
"github.com/grafana/grafana/pkg/storage/unified/sql/db"
|
|
)
|
|
|
|
// NewDB converts a *sql.DB to a db.DB.
|
|
func NewDB(d *sql.DB, driverName string) db.DB {
|
|
ret := sqlDB{
|
|
DB: d,
|
|
driverName: driverName,
|
|
}
|
|
ret.WithTxFunc = db.NewWithTxFunc(ret.BeginTx)
|
|
|
|
return ret
|
|
}
|
|
|
|
type sqlDB struct {
|
|
*sql.DB
|
|
db.WithTxFunc
|
|
driverName string
|
|
}
|
|
|
|
func (d sqlDB) DriverName() string {
|
|
return d.driverName
|
|
}
|
|
|
|
func (d sqlDB) QueryContext(ctx context.Context, query string, args ...any) (db.Rows, error) {
|
|
return d.DB.QueryContext(ctx, query, args...)
|
|
}
|
|
|
|
func (d sqlDB) QueryRowContext(ctx context.Context, query string, args ...any) db.Row {
|
|
return d.DB.QueryRowContext(ctx, query, args...)
|
|
}
|
|
|
|
func (d sqlDB) BeginTx(ctx context.Context, opts *sql.TxOptions) (db.Tx, error) {
|
|
tx, err := d.DB.BeginTx(ctx, opts)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return sqlTx{tx}, err
|
|
}
|
|
|
|
type sqlTx struct {
|
|
*sql.Tx
|
|
}
|
|
|
|
func (d sqlTx) QueryContext(ctx context.Context, query string, args ...any) (db.Rows, error) {
|
|
return d.Tx.QueryContext(ctx, query, args...)
|
|
}
|
|
|
|
func (d sqlTx) QueryRowContext(ctx context.Context, query string, args ...any) db.Row {
|
|
return d.Tx.QueryRowContext(ctx, query, args...)
|
|
}
|