models.go 1.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package models
  2. import (
  3. "github.com/astaxie/beego/config"
  4. _ "github.com/go-sql-driver/mysql"
  5. "github.com/go-xorm/xorm"
  6. )
  7. var (
  8. Dao *xorm.Engine
  9. )
  10. func init() {
  11. Dao = NewDAO()
  12. }
  13. // NewDAO 初始化数据库连接
  14. func NewDAO() *xorm.Engine {
  15. dbType := "mysql"
  16. dns := getMysqlDns()
  17. dao, err := xorm.NewEngine(dbType, dns)
  18. // dao.ShowSQL()
  19. if err != nil {
  20. panic(err)
  21. return nil
  22. }
  23. Dao = dao
  24. return dao
  25. }
  26. func getMysqlDns() string {
  27. dbconf, _ := config.NewConfig("ini", "conf/db.conf")
  28. // db_type := dbconf.DefaultString("db_type", "mysql")
  29. conProt := dbconf.DefaultString("con_protocol", "tcp")
  30. dbAddr := dbconf.DefaultString("db_addr", "localhost")
  31. dbPort := dbconf.DefaultString("db_port", "3306")
  32. userName := dbconf.DefaultString("username", "root")
  33. password := dbconf.String("password")
  34. database := dbconf.String("database")
  35. // dbprefix := dbconf.String("dbprefix")
  36. // db_debug := dbconf.DefaultBool("db_debug", false)
  37. charSet := dbconf.DefaultString("char_set", "utf8")
  38. dns := userName
  39. if len(password) > 0 {
  40. dns += ":" + password
  41. }
  42. dns += "@" + conProt + "(" + dbAddr + ":" + dbPort + ")" + "/" + database + "?charset=" + charSet
  43. return dns
  44. }