1 Star 1 Fork 0

csingo/cDB

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
MysqlConnector.go 1.58 KB
一键复制 编辑 原始数据 按行查看 历史
chenxuyi 提交于 3年前 . update
package cDB
import (
"gitee.com/csingo/cHelper"
"gitee.com/csingo/cLog"
"gorm.io/driver/mysql"
"gorm.io/gorm"
"gorm.io/gorm/schema"
"time"
)
type MysqlConnector struct{}
func (i *MysqlConnector) Connect(conf DatabaseConfDriverInterface) *gorm.DB {
var driverConf *DatabaseConf_MySql
var ok bool
if driverConf, ok = conf.(*DatabaseConf_MySql); !ok {
return nil
}
dsn := driverConf.Username + ":" +
driverConf.Password + "@tcp(" +
driverConf.Host + ":" +
cHelper.ToString(driverConf.Port) + ")/" +
driverConf.Database + "?charset=" +
driverConf.Charset + "&parseTime=True"
cLog.WithContext(nil, map[string]interface{}{
"source": "cDB.MysqlConnector.Connect",
"dsn": dsn,
}).Debug("创建数据库连接")
conn := mysql.Open(dsn)
db, err := gorm.Open(conn, &gorm.Config{
//Logger: logger.Default.LogMode(logger.Info),
NamingStrategy: schema.NamingStrategy{
SingularTable: true, // 使用单数表名
},
})
if err != nil {
cLog.WithContext(nil, map[string]interface{}{
"source": "cDB.MysqlConnector.Connect",
"err": err.Error(),
}).Panic("数据库连接异常")
}
sqlDB, err := db.DB()
if err != nil {
cLog.WithContext(nil, map[string]interface{}{
"source": "cDB.MysqlConnector.Connect",
"err": err.Error(),
}).Panic("数据库连接异常")
}
sqlDB.SetMaxIdleConns(driverConf.Pool.MaxIdleConnections)
sqlDB.SetMaxOpenConns(driverConf.Pool.MaxConnections)
sqlDB.SetConnMaxLifetime(time.Duration(driverConf.Pool.ConnectTimeout) * time.Second)
sqlDB.SetConnMaxIdleTime(time.Duration(driverConf.Pool.MaxIdleTime) * time.Second)
return db
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/csingo/cDB.git
git@gitee.com:csingo/cDB.git
csingo
cDB
cDB
v0.0.194

搜索帮助