common.go 796 B

123456789101112131415161718192021222324252627282930
  1. package dao
  2. import (
  3. "fmt"
  4. _ "github.com/go-sql-driver/mysql"
  5. "github.com/jinzhu/gorm"
  6. "iot_manager_service/config"
  7. "net/url"
  8. )
  9. var GDb *gorm.DB
  10. func InitDB() {
  11. cfg := config.Instance()
  12. dsn := cfg.Database.User + ":" + cfg.Database.Password + "@tcp(" + cfg.Database.Host + ":" + cfg.Database.Port + ")/" + cfg.Database.Name + "?charset=utf8&parseTime=True" + "&loc=" + url.QueryEscape(cfg.Database.Timezone)
  13. db0, err := gorm.Open("mysql", dsn)
  14. if err != nil {
  15. panic(err)
  16. } else {
  17. GDb = db0
  18. GDb.DB().SetMaxOpenConns(32)
  19. GDb.DB().SetMaxIdleConns(5)
  20. GDb.LogMode(false)
  21. err = GDb.AutoMigrate(&LampPoleGroup{}, &LampPole{}, &Gateway{}, &GatewayRelation{}, &Transformer{},
  22. &LightControl{}).Error
  23. if err != nil {
  24. panic(fmt.Sprintf("AutoMigrate err : %v", err))
  25. }
  26. }
  27. }