1 Star 0 Fork 0

李小程/blog-lib

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
gorm.go 1.26 KB
一键复制 编辑 原始数据 按行查看 历史
LiXiaoCheng 提交于 2025-07-19 11:08 +08:00 . init
package database
import (
"fmt"
"log"
"gitee.com/xchengli/blog-lib/config"
"gorm.io/driver/mysql"
"gorm.io/gorm"
"gorm.io/gorm/logger"
)
var DB *gorm.DB // GORM数据库实例
// Init 初始化GORM数据库连接
func Init() {
dsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8&parseTime=True&loc=Local",
config.DbCfg.DbUser,
config.DbCfg.DbPass,
config.DbCfg.DbHost,
config.DbCfg.DbPort,
config.DbCfg.DbName,
)
var err error
DB, err = gorm.Open(mysql.Open(dsn), &gorm.Config{
Logger: logger.Default.LogMode(logger.Info),
})
if err != nil {
log.Fatal("Failed to connect to database:", err)
}
// 获取原生SQL数据库连接以设置连接池参数
sqlDB, err := DB.DB()
if err != nil {
log.Fatal("Failed to get SQL DB:", err)
}
// 设置连接池参数
sqlDB.SetMaxOpenConns(100)
sqlDB.SetMaxIdleConns(10)
log.Println("Database connected successfully")
}
// GetDB 获取GORM数据库实例
func GetDB() *gorm.DB {
return DB
}
// Close 关闭数据库连接
func Close() {
// 关闭GORM数据库连接
if DB != nil {
sqlDB, err := DB.DB()
if err == nil {
sqlDB.Close()
log.Println("Database connection closed")
}
}
// 关闭Redis连接
if RedisConn != nil {
RedisConn.Close()
log.Println("Redis connection closed")
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/xchengli/blog-lib.git
git@gitee.com:xchengli/blog-lib.git
xchengli
blog-lib
blog-lib
7bad096cf672

搜索帮助