1 Star 0 Fork 0

go-better/go

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
shards.go 1.54 KB
一键复制 编辑 原始数据 按行查看 历史
bughou 提交于 2022-03-21 20:37 +08:00 . save
package create
import (
"database/sql"
"fmt"
"time"
"gitee.com/go-better/dev/config/config"
"gitee.com/go-better/dev/db/pg"
)
func (c Creation) setupShard(rawDb *sql.DB, shardNo int, settings config.ShardsSettings) error {
if c.typ != `postgres` || shardNo == 0 || settings.IdSeqIncrementBy == 0 {
return nil
}
db := pg.New(rawDb, 10*time.Second)
var idSeqNames []string
if err := db.Query(&idSeqNames, getQueryIdSeqsSql()); err != nil {
return err
}
for _, seqName := range idSeqNames {
if err := setupSequence(db, seqName, settings.IdSeqIncrementBy, shardNo); err != nil {
return err
}
}
return nil
}
func setupSequence(db *pg.DB, seqName string, incrementBy, restartWith int) error {
var isCalled bool
if err := db.Query(&isCalled, `SELECT is_called from `+seqName); err != nil {
return err
}
if isCalled {
return nil
}
_, err := db.Exec(fmt.Sprintf(
"ALTER SEQUENCE %s INCREMENT BY %d RESTART WITH %d", seqName, incrementBy, restartWith,
))
return err
}
var queryIdSeqsSql string
func getQueryIdSeqsSql() string {
if queryIdSeqsSql == `` {
const prefix, suffix = `nextval('`, `'::regclass)`
queryIdSeqsSql = fmt.Sprintf(
"SELECT substring(column_default FROM %d FOR length(column_default)-%d) AS sequence",
len(prefix)+1, len(prefix)+len(suffix),
) + `
FROM information_schema.columns
WHERE table_schema NOT IN ('pg_catalog', 'information_schema') AND
column_name = 'id' AND column_default LIKE $$` + prefix + `%_id_seq` + suffix + `$$
ORDER BY column_default`
}
return queryIdSeqsSql
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/go-better/go.git
git@gitee.com:go-better/go.git
go-better
go
go
d31700df43a9

搜索帮助