common.go 875 B

123456789101112131415161718192021222324252627282930313233343536373839
  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(
  22. &LampPoleGroup{},
  23. &LampPole{},
  24. &Gateway{},
  25. &GatewayRelation{},
  26. &Transformer{},
  27. &LightControl{},
  28. &Garbage{},
  29. &GarbageWayGroup{},
  30. &OnDemandGroup{},
  31. ).Error
  32. if err != nil {
  33. panic(fmt.Sprintf("AutoMigrate err : %v", err))
  34. }
  35. }
  36. }