LightStrategyDao.go 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package dao
  2. import (
  3. "github.com/jinzhu/gorm"
  4. "time"
  5. )
  6. type LightStrategy struct {
  7. ID int `gorm:"primary key" json:"id"` //编号
  8. LightName string `gorm:"type:varchar(64)" json:"lightName"` //策略名称
  9. LightControlType int `gorm:"type:int" json:"lightControlType"` //灯控类型 设置 1=485,2=nb-iot
  10. OptoSensorID int `gorm:"type:int" json:"optoSensorID"` //光传感器ID
  11. StartTime string `gorm:"type:date" json:"startTime"` //策略期限开始时间
  12. EndTime string `gorm:"type:date" json:"endTime"` //策略期限结束时间
  13. IsAllYear int `gorm:"type:int;default 1" json:"isAllYear"` //全年设置2=是,1=否
  14. IsAutomaticRenewal int `gorm:"type:int;default 1" json:"isAutomaticRenewal"` //自动续期设置 2=是,1=否
  15. CreateTime time.Time `gorm:"type:datetime" json:"createTime"` //新增时间
  16. CreateUser string `gorm:"type:varchar(60)" json:"createUser"` //新增记录操作用户ID
  17. UpdateTime time.Time `gorm:"type:datetime" json:"updateTime"` //修改时间
  18. UpdateUser string `gorm:"type:varchar(60)" json:"updateUser"` //修改用户
  19. IsDeleted int `gorm:"type:int;default 0" json:"isDeleted"` //是否删除 0=未删除,1=删除
  20. Status int `gorm:"type:int;default 1" json:"status"` //状态 0=正常,1=异常
  21. TenantID string `gorm:"type:varchar(12)" json:"tenantID"` //租户id
  22. LightSn string `gorm:"type:varchar(64)" json:"lightSn"` //策略编码
  23. ManualTime int `gorm:"type:int;default 0" json:"manualTime"` //手动控制时间
  24. }
  25. func (LightStrategy) TableName() string {
  26. return "t_strategy_light"
  27. }
  28. func (c *LightStrategy) Delete() error {
  29. return Db.Model(&c).Where("id = ?", c.ID).Updates(map[string]interface{}{"update_time": c.UpdateTime,
  30. "update_user": c.UpdateUser, "is_deleted": c.IsDeleted}).Error
  31. }
  32. func (c LightStrategy) IsExistedBySN() bool {
  33. var count = 0
  34. _ = Db.Model(&c).Where(" light_sn = ? and is_deleted = ?",
  35. c.LightSn, c.IsDeleted).Count(&count).Error
  36. return count > 0
  37. }
  38. func (c LightStrategy) IsExistedByNameAndCode() bool {
  39. var Strategies []LightStrategy
  40. err := Db.Model(&c).Where("gateway_sn = ? and is_deleted = ?",
  41. c.TenantID, c.IsDeleted).Find(&Strategies).Error
  42. if gorm.IsRecordNotFoundError(err) {
  43. return false
  44. }
  45. for _, d := range Strategies {
  46. if d.ID != c.ID {
  47. return true
  48. }
  49. }
  50. return false
  51. }
  52. func (c *LightStrategy) Create() error {
  53. return Db.Model(&c).Save(&c).Error
  54. }
  55. func (c *LightStrategy) Update() error {
  56. return Db.Model(&c).Where(" id = ? ", c.ID).Update(&c).Error
  57. }
  58. func (c *LightStrategy) GetStrategy() error {
  59. err := Db.Model(&c).Where(" id = ? ", c.ID).First(&c).Error
  60. return err
  61. }
  62. func (c LightStrategy) GetStrategies(offset, limit int) ([]LightStrategy, error) {
  63. var Strategys []LightStrategy
  64. err := Db.Model(&c).Where(" name like ? and is_deleted = 0", "%"+c.LightName+"%").Offset(offset).Limit(limit).Find(&Strategys).Error
  65. return Strategys, err
  66. }
  67. func (c LightStrategy) GetAllStrategies() ([]*LightStrategy, error) {
  68. var Strategys []*LightStrategy
  69. err := Db.Model(&c).Where(" tenant_id = ? and is_deleted = ? ", c.TenantID, c.IsDeleted).Scan(&Strategys).Error
  70. return Strategys, err
  71. }