| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 | package sqlw// TODO: rework all with context from request// https://golang.org/pkg/database/sql/import (	"database/sql"	_ "github.com/go-sql-driver/mysql"	"errors"	"time"	"golang-fave/consts")type Rows = sql.Rowstype DB struct {	db *sql.DB}var ErrNoRows = sql.ErrNoRowsfunc Open(driverName, dataSourceName string) (*DB, error) {	db, err := sql.Open(driverName, dataSourceName)	if err != nil {		if consts.ParamDebug {			log("[CM] OPEN", time.Now(), err, true)		}		return nil, err	}	if consts.ParamDebug {		log("[CM] OPEN", time.Now(), err, true)	}	return &DB{db: db}, err}func (this *DB) Close() error {	if consts.ParamDebug {		err := this.db.Close()		log("[CM] CLOSE", time.Now(), err, true)		return err	}	return this.db.Close()}func (this *DB) Ping() error {	if consts.ParamDebug {		err := this.db.Ping()		log("[CM] PING", time.Now(), err, true)		return err	}	return this.db.Ping()}func (this *DB) SetConnMaxLifetime(d time.Duration) {	this.db.SetConnMaxLifetime(d)}func (this *DB) SetMaxIdleConns(n int) {	this.db.SetMaxIdleConns(n)}func (this *DB) SetMaxOpenConns(n int) {	this.db.SetMaxOpenConns(n)}func (this *DB) QueryRow(query string, args ...interface{}) *sql.Row {	if consts.ParamDebug {		s := time.Now()		r := this.db.QueryRow(query, args...)		log(query, s, nil, false)		return r	}	return this.db.QueryRow(query, args...)}func (this *DB) Begin() (*Tx, error) {	tx, err := this.db.Begin()	if err != nil {		if consts.ParamDebug {			log("[TX] TRANSACTION START", time.Now(), err, true)		}		return nil, err	}	if consts.ParamDebug {		s := time.Now()		log("[TX] TRANSACTION START", s, err, true)		return &Tx{tx, s}, err	}	return &Tx{tx, time.Now()}, err}func (this *DB) Query(query string, args ...interface{}) (*sql.Rows, error) {	if consts.ParamDebug {		s := time.Now()		r, e := this.db.Query(query, args...)		log(query, s, e, false)		return r, e	}	return this.db.Query(query, args...)}func (this *DB) Exec(query string, args ...interface{}) (sql.Result, error) {	if consts.ParamDebug {		s := time.Now()		r, e := this.db.Exec(query, args...)		log(query, s, e, false)		return r, e	}	return this.db.Exec(query, args...)}func (this *DB) Transaction(queries func(tx *Tx) error) error {	if queries == nil {		return errors.New("queries is not set for transaction")	}	tx, err := this.Begin()	if err != nil {		return err	}	err = queries(tx)	if err != nil {		tx.Rollback()		return err	}	return tx.Commit()}
 |