ipld-eth-statedb/sql/pgx.go
Roy Crihfield 3625e22949 Reorganize packages
* direct_by_leaf/ is original StateDB package
* sql/ for SQL DB interfaces
2023-04-24 18:34:49 +08:00

42 lines
994 B
Go

package sql
import (
"context"
"github.com/jackc/pgconn"
"github.com/jackc/pgx/v4/pgxpool"
)
var _ Driver = &PGXDriver{}
// PGXDriver driver, implements Driver
type PGXDriver struct {
ctx context.Context
db *pgxpool.Pool
}
// NewPGXDriverFromPool returns a new pgx driver for Postgres
func NewPGXDriverFromPool(ctx context.Context, db *pgxpool.Pool) *PGXDriver {
return &PGXDriver{ctx: ctx, db: db}
}
// QueryRow satisfies sql.Database
func (driver *PGXDriver) QueryRow(ctx context.Context, sql string, args ...interface{}) ScannableRow {
return driver.db.QueryRow(ctx, sql, args...)
}
// Exec satisfies sql.Database
func (pgx *PGXDriver) Exec(ctx context.Context, sql string, args ...interface{}) (Result, error) {
res, err := pgx.db.Exec(ctx, sql, args...)
return resultWrapper{ct: res}, err
}
type resultWrapper struct {
ct pgconn.CommandTag
}
// RowsAffected satisfies sql.Result
func (r resultWrapper) RowsAffected() (int64, error) {
return r.ct.RowsAffected(), nil
}