db_client 面向接口实现
This commit is contained in:
@ -36,13 +36,13 @@ func init() {
|
||||
func NewWrapperClient() *wrapperClient {
|
||||
return &wrapperClient{
|
||||
lock: &sync.RWMutex{},
|
||||
clientTable: make(map[string]*define.DBClient),
|
||||
clientTable: make(map[string]abstract.IWrapperDatabaseClient),
|
||||
}
|
||||
}
|
||||
|
||||
type wrapperClient struct {
|
||||
lock *sync.RWMutex
|
||||
clientTable map[string]*define.DBClient
|
||||
clientTable map[string]abstract.IWrapperDatabaseClient
|
||||
logger *zap.Logger
|
||||
}
|
||||
|
||||
@ -73,7 +73,7 @@ func (c *wrapperClient) AddWithConfigFile(cfgFilePath string, logInstance *zap.L
|
||||
//
|
||||
// Date : 20:41 2023/4/18
|
||||
func (c *wrapperClient) AddWithConfig(flag string, logInstance *zap.Logger, databaseConfig *define.Database, extraFieldList []string) error {
|
||||
dbClient := &define.DBClient{
|
||||
dbClient := &DBClient{
|
||||
DbFlag: flag,
|
||||
LoggerInstance: logInstance,
|
||||
ExtraFieldList: extraFieldList,
|
||||
@ -158,12 +158,12 @@ func (c *wrapperClient) getCfg(cfgPath string) (*define.CfgFile, error) {
|
||||
// Author : go_developer@163.com<白茶清欢>
|
||||
//
|
||||
// Date : 19:32 2022/6/5
|
||||
func (c *wrapperClient) GetDBClient(dbFlag string) (*define.DBClient, error) {
|
||||
func (c *wrapperClient) GetDBClient(dbFlag string) (abstract.IWrapperDatabaseClient, error) {
|
||||
c.lock.RLock()
|
||||
defer c.lock.RUnlock()
|
||||
var (
|
||||
exist bool
|
||||
dbClient *define.DBClient
|
||||
dbClient abstract.IWrapperDatabaseClient
|
||||
)
|
||||
if dbClient, exist = c.clientTable[dbFlag]; !exist {
|
||||
return nil, fmt.Errorf("%s 标识的数据库实例不存在! ", dbFlag)
|
||||
@ -179,7 +179,7 @@ func (c *wrapperClient) GetDBClient(dbFlag string) (*define.DBClient, error) {
|
||||
func (c *wrapperClient) GetMasterClient(ctx context.Context, dbFlag string) (*gorm.DB, error) {
|
||||
var (
|
||||
err error
|
||||
dbClient *define.DBClient
|
||||
dbClient abstract.IWrapperDatabaseClient
|
||||
)
|
||||
if dbClient, err = c.GetDBClient(dbFlag); nil != err {
|
||||
return nil, err
|
||||
@ -195,7 +195,7 @@ func (c *wrapperClient) GetMasterClient(ctx context.Context, dbFlag string) (*go
|
||||
func (c *wrapperClient) GetSlaveClient(ctx context.Context, dbFlag string) (*gorm.DB, error) {
|
||||
var (
|
||||
err error
|
||||
dbClient *define.DBClient
|
||||
dbClient abstract.IWrapperDatabaseClient
|
||||
)
|
||||
if dbClient, err = c.GetDBClient(dbFlag); nil != err {
|
||||
return nil, err
|
||||
|
Reference in New Issue
Block a user