Skip to content
  • P
    Projects
  • G
    Groups
  • S
    Snippets
  • Help

黄成意 / go_sku_server

  • This project
    • Loading...
  • Sign in
Go to a project
  • Project
  • Repository
  • Issues 0
  • Merge Requests 0
  • Pipelines
  • Wiki
  • Snippets
  • Settings
  • Activity
  • Graph
  • Charts
  • Create a new issue
  • Jobs
  • Commits
  • Issue Boards
  • Files
  • Commits
  • Branches
  • Tags
  • Contributors
  • Graph
  • Compare
  • Charts
Find file
BlameHistoryPermalink
Switch branch/tag
  • go_sku_server
  • pkg
  • mysql
  • mysql.go
  • huangchengyi's avatar
    1.0 · d62003c2
    huangchengyi committed 4 years ago
    d62003c2
mysql.go 1.12 KB
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
package mysql

import (
	"fmt"
	_ "github.com/go-sql-driver/mysql"
	"github.com/go-xorm/xorm"
	"go_sku_server/pkg/config"
	"go_sku_server/pkg/e"
)

var DatabaseConMap map[string]*xorm.Engine

func Setup() error {
	DatabaseConMap = make(map[string]*xorm.Engine, 0)
	DatabaseList := config.BuildDatabaseList()
	var err error
	//循环生成数据库链接
	for conName, db := range DatabaseList {
		userName := db.UserName
		password := db.Password
		host := db.Host
		database := db.Database

		dataSourceName := fmt.Sprintf("%s:%s@tcp(%s)/%s?charset=utf8", userName, password, host, database)

		DatabaseConMap[conName], err = xorm.NewEngine("mysql", dataSourceName)
		if err != nil {
			return e.NewFatalError(err.Error()) //这里返回致命异常
		}

		//日志打印SQL
		ShowSql,_ := config.Get("xorm.ShowSQL").Bool()
		DatabaseConMap[conName].ShowSQL(ShowSql)

		//设置连接池的空闲数大小
		DatabaseConMap[conName].SetMaxIdleConns(db.MaxIdleCons)
		//设置最大打开连接数
		DatabaseConMap[conName].SetMaxOpenConns(db.MaxOpenCons)

	}

	return nil
}

func Conn(conName string) *xorm.Engine {
	return DatabaseConMap[conName]
}