1 Star 0 Fork 0

chuang / gorm-shard

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
conn_pool.go 2.50 KB
一键复制 编辑 原始数据 按行查看 历史
chuang 提交于 2024-02-29 10:29 . 搬运工
package sharding
import (
"context"
"database/sql"
"gorm.io/gorm"
)
// ConnPool Implement a ConnPool for replace db.Statement.ConnPool in Gorm
type ConnPool struct {
// db, This is global db instance
sharding *Sharding
gorm.ConnPool
}
func (pool *ConnPool) String() string {
return "gorm:sharding:conn_pool"
}
func (pool ConnPool) PrepareContext(ctx context.Context, query string) (*sql.Stmt, error) {
return pool.ConnPool.PrepareContext(ctx, query)
}
func (pool ConnPool) ExecContext(ctx context.Context, query string, args ...any) (sql.Result, error) {
ftQuery, stQuery, table, err := pool.sharding.resolve(query, args...)
if err != nil {
return nil, err
}
pool.sharding.querys.Store("last_query", stQuery)
if table != "" {
if r, ok := pool.sharding.configs[table]; ok {
if r.DoubleWrite {
pool.ConnPool.ExecContext(ctx, ftQuery, args...)
}
}
}
return pool.ConnPool.ExecContext(ctx, stQuery, args...)
}
// https://github.com/go-gorm/gorm/blob/v1.21.11/callbacks/query.go#L18
func (pool ConnPool) QueryContext(ctx context.Context, query string, args ...any) (*sql.Rows, error) {
ftQuery, stQuery, table, err := pool.sharding.resolve(query, args...)
if err != nil {
return nil, err
}
pool.sharding.querys.Store("last_query", stQuery)
if table != "" {
if r, ok := pool.sharding.configs[table]; ok {
if r.DoubleWrite {
pool.ConnPool.ExecContext(ctx, ftQuery, args...)
}
}
}
return pool.ConnPool.QueryContext(ctx, stQuery, args...)
}
func (pool ConnPool) QueryRowContext(ctx context.Context, query string, args ...any) *sql.Row {
_, query, _, _ = pool.sharding.resolve(query, args...)
pool.sharding.querys.Store("last_query", query)
return pool.ConnPool.QueryRowContext(ctx, query, args...)
}
// BeginTx Implement ConnPoolBeginner.BeginTx
func (pool *ConnPool) BeginTx(ctx context.Context, opt *sql.TxOptions) (gorm.ConnPool, error) {
if basePool, ok := pool.ConnPool.(gorm.ConnPoolBeginner); ok {
return basePool.BeginTx(ctx, opt)
}
return pool, nil
}
// Implement TxCommitter.Commit
func (pool *ConnPool) Commit() error {
if _, ok := pool.ConnPool.(*sql.Tx); ok {
return nil
}
if basePool, ok := pool.ConnPool.(gorm.TxCommitter); ok {
return basePool.Commit()
}
return nil
}
// Implement TxCommitter.Rollback
func (pool *ConnPool) Rollback() error {
if _, ok := pool.ConnPool.(*sql.Tx); ok {
return nil
}
if basePool, ok := pool.ConnPool.(gorm.TxCommitter); ok {
return basePool.Rollback()
}
return nil
}
func (pool *ConnPool) Ping() error {
return nil
}
Go
1
https://gitee.com/hellochuang/gorm-shard.git
git@gitee.com:hellochuang/gorm-shard.git
hellochuang
gorm-shard
gorm-shard
v1.0.0

搜索帮助

53164aa7 5694891 3bd8fe86 5694891