-
Notifications
You must be signed in to change notification settings - Fork 213
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
v7 api changed: how to new TxDatabase #95
Comments
The standard way of using this library for that would be to use If I changed |
I added the change I described in my previous comment. This should allow you to create a new goqu db instance with your sqlx instance. From there you can just do Let me know if this helps! |
thanks, You're so quick! I have some Legacy Code (sqlx and goqu.v5) , mixture use sqlx and goqu.v5 in one tx like this : import (
"context"
"database/sql"
"github.com/jmoiron/sqlx"
"github.com/sirupsen/logrus"
"gopkg.in/doug-martin/goqu.v5"
_ "gopkg.in/doug-martin/goqu.v5/adapters/mysql"
)
func XXXXXXQuery(){
mydatebase:=NewDb(sqlx.MustConnect("mysql", "localhost:3306................"))
err = mydatebase.InTxContext(ctx, &sql.TxOptions{ReadOnly: true}, func(myTx *mysqlx.Tx) error {
//use sqlx tx
row := tx.Tx.QueryRowx("select * from abc")
...
// use goqu Tx
found, err := tx.Goqu.From(goqu.I("abc").As("c")).Select("c.xxx").ScanStruct(&res)
...
return err
})
}
// DB ext
type DB struct {
DB *sqlx.DB
Goqu *goqu.Database
}
// Tx ext
type Tx struct {
Tx *sqlx.Tx
Goqu *goqu.TxDatabase
}
// NewDb
func NewDb(db *sqlx.DB) *DB {
return &DB{
DB: db,
Goqu: goqu.New("mysql", db.DB),
}
}
// InTxContext
func (db *DB) InTxContext(ctx context.Context, opts *sql.TxOptions, txFunc func(tx *Tx) error) (err error) {
tx, err := db.DB.BeginTxx(ctx, opts)
if err != nil {
return
}
return inTx(tx, txFunc)
}
//InTx ref: https://stackoverflow.com/questions/16184238/database-sql-tx-detecting-commit-or-rollback
func (db *DB) InTx(txFunc func(tx *Tx) error) (err error) {
tx, err := db.DB.Beginx()
if err != nil {
return
}
return inTx(tx, txFunc)
}
func inTx(sqlxTx *sqlx.Tx, txFunc func(tx *Tx) error) (err error) {
tx := &Tx{sqlxTx, &goqu.TxDatabase{Dialect: sqlxTx.DriverName(), Tx: sqlxTx.Tx}}
defer func() {
if r := recover(); r != nil {
//已在一个panic中,不理会Rollback的err
err := tx.Tx.Rollback()
logrus.Error(err)
// re-throw panic after Rollback
panic(r)
}
if err != nil {
//err已非空,不理会Rollback的err
err := tx.Tx.Rollback()
logrus.Error(err)
return
}
// err==nil, commit; 如果commit失败,则返回err
err = tx.Tx.Commit()
}()
err = txFunc(tx)
return err
}
in goqu.v7 , I saw your new code,Still unable to do this:
|
* [ADDED] Exposed `goqu.NewTx` to allow creating a goqu tx directly from a `sql.Tx` instead of using `goqu.Database#Begin` #95
Ok I added a |
in goqu.v5, i can use
goqu.TxDatabase{...}
create a goqu tx, but v7 how to do this :The text was updated successfully, but these errors were encountered: