12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- package dao
- import (
- "context"
- "go-common/app/admin/main/growup/conf"
- "go-common/library/database/orm"
- "go-common/library/database/sql"
- "go-common/library/log"
- httpx "go-common/library/net/http/blademaster"
- "github.com/jinzhu/gorm"
- )
- // Dao dao
- type Dao struct {
- c *conf.Config
- db *gorm.DB
- rddb *sql.DB
- client *httpx.Client
- VideoURL string
- ColumnURL string
- }
- // New fn
- func New(c *conf.Config) (d *Dao) {
- d = &Dao{
- c: c,
- db: orm.NewMySQL(c.ORM.Growup),
- rddb: sql.NewMySQL(c.ORM.Allowance),
- client: httpx.NewClient(c.HTTPClient),
- VideoURL: c.Host.VideoType + "/videoup/types",
- ColumnURL: c.Host.ColumnType + "/x/article/categories",
- }
- d.initORM()
- return
- }
- func (d *Dao) initORM() {
- d.db.LogMode(true)
- }
- // Ping check conn of db
- func (d *Dao) Ping(c context.Context) (err error) {
- if d.db != nil {
- err = d.db.DB().PingContext(c)
- }
- return
- }
- // Close close conn of db
- func (d *Dao) Close() {
- if d.db != nil {
- d.db.Close()
- }
- }
- // BeginTran begin tran
- func (d *Dao) BeginTran(c context.Context) (tx *sql.Tx, err error) {
- return d.rddb.Begin(c)
- }
- // Exec do exec
- func (d *Dao) Exec(c context.Context, sql string) (rows int64, err error) {
- res, err := d.rddb.Exec(c, sql)
- if err != nil {
- return
- }
- return res.RowsAffected()
- }
- // DoInTx .
- func (d *Dao) DoInTx(c context.Context, txFunc func(*sql.Tx) error) (err error) {
- tx, err := d.rddb.Begin(c)
- if err != nil {
- log.Error("d.rddb.Begin err(%v)", err)
- return
- }
- defer func() {
- if err != nil {
- if err1 := tx.Rollback(); err1 != nil {
- log.Error("tx.Rollback err(%v)", err1)
- }
- return
- }
- }()
- err = txFunc(tx)
- if err != nil {
- return
- }
- if err = tx.Commit(); err != nil {
- log.Error("tx.Commit err(%v)", err)
- }
- return
- }
|