1 Star 0 Fork 0

东方老僧/lsknife

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
mysql.go 4.32 KB
一键复制 编辑 原始数据 按行查看 历史
DFFISH 提交于 2025-09-02 09:21 +08:00 . 1.将配置文件改成toml格式
package mysql
import (
"errors"
"gitee.com/dongffish/lsknife/database"
"gorm.io/driver/mysql"
"gorm.io/gorm"
"gorm.io/gorm/logger"
"log"
"os"
"time"
)
// GormMysql 初始化Mysql数据库。
// 参数PasswordDecryptionKey密码解密密钥,密钥为空时表示配置文件中的密码是明文.
// 密码加密是用 encrypt.TripleDesDecrypt 进行加密的
// 需要用一个toml类型的配置文件: config.toml
func GormMysql(iniSection, PasswordDecryptionKey string) (*gorm.DB, error) {
if iniSection == "" {
iniSection = "DATABASE"
}
dbCfg, err := database.ReadDBConfig(iniSection, PasswordDecryptionKey)
if err != nil {
return nil, errors.New("数据库配置文件config.toml读取失败!" + err.Error())
}
var gormCfg gorm.Config
var customLogger logger.Interface
gormCfg.DisableForeignKeyConstraintWhenMigrating = true
// fmt.Println("dbCfg.ShowSQL =", dbCfg.ShowSQL)
if dbCfg.ShowSQL == 1 { //显示所有SQL
customLogger = logger.New(
log.New(os.Stdout, "\r\n", log.LstdFlags),
logger.Config{
IgnoreRecordNotFoundError: true, // 忽略 record not found 错误
LogLevel: logger.Info,
},
)
} else {
customLogger = logger.New(
log.New(os.Stdout, "\r\n", log.LstdFlags),
logger.Config{
IgnoreRecordNotFoundError: true, // 忽略 record not found 错误
LogLevel: logger.Error,
},
)
}
gormCfg.Logger = customLogger
db, err := gorm.Open(mysql.New(mysql.Config{
DSN: dbCfg.ConnString,
DefaultStringSize: 256, // string 类型字段的默认长度
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置
}), &gormCfg)
if err != nil {
return nil, errors.New("数据库Open失败! " + err.Error())
}
sqlDB, err := db.DB()
if sqlDB == nil {
return nil, errors.New("数据库nil")
}
if err != nil {
return nil, errors.New("db.DB() Error ! " + err.Error())
}
if sqlDB.Ping() != nil {
return nil, errors.New("数据库连接失败! ")
}
// 以下设置连接池信息
sqlDB.SetMaxIdleConns(dbCfg.MaxIdleConns) // 用于设置连接池中空闲连接的最在数量
sqlDB.SetMaxOpenConns(dbCfg.MaxOpenConns) // 用于打开数据连接的最大数量
sqlDB.SetConnMaxLifetime(time.Second * time.Duration(dbCfg.ConnMaxLifetime)) // 设置了连接可复用的最大时间(秒)
return db, err
}
// GormMysqlByDSN 根据DSN初始化Mysql数据库
func GormMysqlByDSN(dsn string) (*gorm.DB, error) {
var gormCfg gorm.Config
db, err := gorm.Open(mysql.New(mysql.Config{
DSN: dsn, //dbCfg.ConnString,
DefaultStringSize: 256, // string 类型字段的默认长度
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置
}), &gormCfg)
if err != nil {
return nil, errors.New("数据库Open失败! " + err.Error())
}
sqlDB, err := db.DB()
if sqlDB == nil {
return nil, errors.New("数据库nil")
}
if err != nil {
return nil, errors.New("db.DB() Error ! " + err.Error())
}
if sqlDB.Ping() != nil {
return nil, errors.New("数据库连接失败! ")
}
// 以下设置连接池信息
MaxIdleConns := 600
MaxOpenConns := 600
ConnMaxLifetime := 150
sqlDB.SetMaxIdleConns(MaxIdleConns) // 用于设置连接池中空闲连接的最在数量
sqlDB.SetMaxOpenConns(MaxOpenConns) // 用于打开数据连接的最大数量
sqlDB.SetConnMaxLifetime(time.Second * time.Duration(ConnMaxLifetime)) // 设置了连接可复用的最大时间(秒)
return db, err
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/dongffish/lsknife.git
git@gitee.com:dongffish/lsknife.git
dongffish
lsknife
lsknife
v0.0.23

搜索帮助