代码拉取完成,页面将自动刷新
package mysql
import (
"database/sql"
. "gitee.com/kristas/booting-go/framework/bean/bean_factory"
appConfig "gitee.com/kristas/booting-go/framework/config"
"gorm.io/driver/mysql"
"gorm.io/gorm"
. "gorm.io/gorm/logger"
"reflect"
"strings"
)
func InitGormDatasource() {
InitDatasource(handleFacade)
}
func handleFacade(config DataSource, db *sql.DB) {
c := GetBean("app_config").(*appConfig.Config)
gormDB, err := gorm.Open(mysql.New(mysql.Config{
Conn: db,
}), &gorm.Config{
Logger: Default.LogMode(gormLogLevelAdapter(c.Logging.Level)),
})
if err != nil {
log.Error("Failed to facade db to gormDB, caused by:", err)
} else {
log.Infof("Successfully connected to db %s", config.Tag)
}
gormBean := GetBean(config.Tag)
reflect.ValueOf(gormBean).Elem().Set(
reflect.ValueOf(gormDB).Elem())
}
func gormLogLevelAdapter(level string) LogLevel {
switch strings.ToLower(level) {
case "panic":
return Silent
case "fatal", "error":
return Error
case "warn", "warning":
return Warn
default:
return Info
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。