123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- package global
- import (
- "database/sql/driver"
- _ "dm"
- dm "dmgorm2"
- "eta_gn/eta_api/utils"
- "fmt"
- "gorm.io/gorm"
- "gorm.io/gorm/logger"
- "gorm.io/gorm/schema"
- "io"
- "log"
- "os"
- "time"
- _ "github.com/go-sql-driver/mysql"
- )
- type LocalTime time.Time
- func InitDm() {
- dmSqlMap := make(map[string]*gorm.DB)
- logWriter := io.MultiWriter(utils.Binlog) //binlog日志,记录到文件中去
- if utils.RunMode == `dev` { // 测试环境,默认输出在控制台,不需要的话,可以注释if里面下面的这行
- logWriter = io.MultiWriter(utils.Binlog, os.Stdout)
- }
- newLogger := logger.New(log.New(logWriter, "\r\n", log.LstdFlags), logger.Config{
- SlowThreshold: 200 * time.Millisecond, //慢sql :200ms
- LogLevel: logger.Info, //记录的日志类型,info代表所有信息都记录
- IgnoreRecordNotFoundError: true, //是否忽略找不到数据错误信息(只是日志记录记录成err还是普通的输出的区别,并不影响业务代码中的:找不到数据行error)
- Colorful: false, //是否颜色输出
- })
- connectDm(utils.MYSQL_URL, "default", newLogger, dmSqlMap, true)
- connectDm(utils.MYSQL_URL_RDDP, "rddp", newLogger, dmSqlMap, false)
- connectDm(utils.MYSQL_URL_EDB, "edb", newLogger, dmSqlMap, false)
- connectDm(utils.MYSQL_URL_DATA, "data", newLogger, dmSqlMap, false)
- connectDm(utils.MYSQL_URL_GL, "gl", newLogger, dmSqlMap, false)
- if utils.MYSQL_AI_URL != "" {
- connectDm(utils.MYSQL_AI_URL, "ai", newLogger, dmSqlMap, false)
- }
- DmSQL = dmSqlMap
- }
- func connectDm(dsn, aliasName string, newLogger logger.Interface, dmSqlMap map[string]*gorm.DB, isDefault bool) {
- if dsn == `` {
- return
- }
- db, err := gorm.Open(dm.Open(dsn), &gorm.Config{
- Logger: newLogger,
- NamingStrategy: schema.NamingStrategy{
- SingularTable: true, // 表示使用单数表名,启用该选项后,GORM 将不会对表名进行复数化处理
- },
- })
- if err != nil {
- panic(fmt.Errorf("mysql 启动异常,数据库:%s;Err:%s", aliasName, err))
- }
- sqlDB, err := db.DB()
- if err != nil {
- panic(fmt.Errorf("mysql 创建连接池失败,数据库:%s;Err:%s", aliasName, err))
- }
- dmSqlMap[aliasName] = db
- if isDefault {
- DEFAULT_DmSQL = db
- }
- sqlDB.SetMaxIdleConns(50)
- sqlDB.SetMaxOpenConns(100)
- sqlDB.SetConnMaxLifetime(10 * time.Minute)
- }
- func (t *LocalTime) MarshalJSON() ([]byte, error) {
- tTime := time.Time(*t)
- if tTime.IsZero() {
- return []byte("\"\""), nil
- }
- return []byte(fmt.Sprintf("\"%v\"", tTime.Format("2006-01-02 15:04:05"))), nil
- }
- func (t LocalTime) Value() (driver.Value, error) {
- var zeroTime time.Time
- tlt := time.Time(t)
- if tlt.UnixNano() == zeroTime.UnixNano() {
- return nil, nil
- }
- return tlt, nil
- }
- func (t *LocalTime) Scan(v interface{}) error {
- if value, ok := v.(time.Time); ok {
- *t = LocalTime(value)
- return nil
- }
- return fmt.Errorf("can not convert %v to timestamp", v)
- }
|