2023-06-15 09:41:30 +08:00
|
|
|
package store
|
|
|
|
|
|
|
|
import (
|
|
|
|
"chatplus/core/types"
|
|
|
|
"gorm.io/driver/mysql"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
"gorm.io/gorm/logger"
|
|
|
|
"gorm.io/gorm/schema"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
func NewGormConfig() *gorm.Config {
|
|
|
|
return &gorm.Config{
|
|
|
|
Logger: logger.Default.LogMode(logger.Warn),
|
|
|
|
NamingStrategy: schema.NamingStrategy{
|
|
|
|
TablePrefix: "chatgpt_", // 设置表前缀
|
|
|
|
SingularTable: false, // 使用单数表名形式
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewMysql(config *gorm.Config, appConfig *types.AppConfig) (*gorm.DB, error) {
|
|
|
|
db, err := gorm.Open(mysql.Open(appConfig.MysqlDns), config)
|
2023-11-27 18:24:52 +08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2023-06-15 09:41:30 +08:00
|
|
|
|
|
|
|
sqlDB, err := db.DB()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
sqlDB.SetMaxIdleConns(32)
|
|
|
|
sqlDB.SetMaxOpenConns(512)
|
|
|
|
sqlDB.SetConnMaxLifetime(time.Hour)
|
2023-11-27 18:24:52 +08:00
|
|
|
|
2023-06-15 09:41:30 +08:00
|
|
|
return db, nil
|
|
|
|
}
|