mirror of
				https://gitee.com/dromara/mayfly-go
				synced 2025-11-04 08:20:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package starter
 | 
						||
 | 
						||
import (
 | 
						||
	"mayfly-go/pkg/config"
 | 
						||
	"mayfly-go/pkg/global"
 | 
						||
 | 
						||
	"gorm.io/driver/mysql"
 | 
						||
	"gorm.io/gorm"
 | 
						||
	"gorm.io/gorm/logger"
 | 
						||
	"gorm.io/gorm/schema"
 | 
						||
)
 | 
						||
 | 
						||
func InitDb() {
 | 
						||
	global.Db = GormMysql()
 | 
						||
}
 | 
						||
 | 
						||
func GormMysql() *gorm.DB {
 | 
						||
	m := config.Conf.Mysql
 | 
						||
	if m == nil || m.Dbname == "" {
 | 
						||
		global.Log.Panic("未找到数据库配置信息")
 | 
						||
		return nil
 | 
						||
	}
 | 
						||
	global.Log.Infof("连接mysql [%s]", m.Host)
 | 
						||
	mysqlConfig := mysql.Config{
 | 
						||
		DSN:                       m.Dsn(), // DSN data source name
 | 
						||
		DefaultStringSize:         191,     // string 类型字段的默认长度
 | 
						||
		DisableDatetimePrecision:  true,    // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持
 | 
						||
		DontSupportRenameIndex:    true,    // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引
 | 
						||
		DontSupportRenameColumn:   true,    // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列
 | 
						||
		SkipInitializeWithVersion: false,   // 根据版本自动配置
 | 
						||
	}
 | 
						||
	ormConfig := &gorm.Config{NamingStrategy: schema.NamingStrategy{
 | 
						||
		TablePrefix:   "t_",
 | 
						||
		SingularTable: true,
 | 
						||
	}, Logger: logger.Default.LogMode(logger.Silent)}
 | 
						||
	if db, err := gorm.Open(mysql.New(mysqlConfig), ormConfig); err != nil {
 | 
						||
		global.Log.Panicf("连接mysql失败! [%s]", err.Error())
 | 
						||
		return nil
 | 
						||
	} else {
 | 
						||
		sqlDB, _ := db.DB()
 | 
						||
		sqlDB.SetMaxIdleConns(m.MaxIdleConns)
 | 
						||
		sqlDB.SetMaxOpenConns(m.MaxOpenConns)
 | 
						||
		return db
 | 
						||
	}
 | 
						||
}
 |