代码拉取完成,页面将自动刷新
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
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。