link_style.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. package bo
  2. import (
  3. "errors"
  4. "fmt"
  5. "scd_check_tools/logger"
  6. "scd_check_tools/models/enum"
  7. "scd_check_tools/tools"
  8. "strconv"
  9. "strings"
  10. "github.com/astaxie/beego/orm"
  11. )
  12. //接线方式模型
  13. type T_data_link_style struct {
  14. Id int `orm:"pk"`
  15. VolLevelId int // '电压等级ID' ,
  16. Name string // 名称
  17. Pic string // '方式图路径' ,
  18. Cr int // '创建人' ,
  19. Ct string `orm:"-"` // '创建时间' ,
  20. Ur int // '更新人' ,
  21. Ut string `orm:"-"` // '更新时间'
  22. }
  23. //接线方式管理对象
  24. type LinkStyleMgr struct {
  25. Model T_data_link_style
  26. DeviceBaseModel
  27. }
  28. var linkstyle_modelDesc = "接线方式"
  29. func init() {
  30. orm.RegisterModel(new(T_data_link_style))
  31. }
  32. func (c *LinkStyleMgr) Exist() (int, bool) {
  33. db := orm.NewOrm()
  34. rowset := []orm.Params{}
  35. _, err := db.Raw("select id from t_data_link_style where vol_level_id=? and name=?", c.Model.VolLevelId, c.Model.Name).Values(&rowset)
  36. if err != nil {
  37. logger.Logger.Error(err)
  38. return 0, true
  39. }
  40. if len(rowset) > 0 {
  41. id, _ := strconv.Atoi(tools.IsEmpty(rowset[0]["id"]))
  42. if c.Model.Id > 0 && c.Model.Id == id {
  43. //发现名称与当前数据记录的相同,判定为不重复
  44. return id, false
  45. }
  46. return id, true
  47. } else {
  48. return 0, false
  49. }
  50. }
  51. //保存接线方式信息
  52. func (c *LinkStyleMgr) Save() (err error) {
  53. dblog := new(SystemLog)
  54. dblog.SetUserInfo(c.GetUserInfo())
  55. dblog.Audittype = enum.AuditType_link_style
  56. dblog.Logtype = enum.LogType_Insert
  57. dblog.Eventtype = enum.OptEventType_Bus
  58. dblog.Eventlevel = enum.OptEventLevel_Hight
  59. _, same := c.Exist()
  60. if same {
  61. //发现名称有相同 的
  62. return errors.New(fmt.Sprintf("在所选电压等级下接线方式[%s]已存在", c.Model.Name))
  63. }
  64. db := orm.NewOrm()
  65. c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
  66. if c.Model.Id == 0 {
  67. _, err = db.Insert(&c.Model)
  68. } else {
  69. _, err = db.Update(&c.Model)
  70. }
  71. if err != nil {
  72. logger.Logger.Error(err)
  73. dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", linkstyle_modelDesc, err.Error(), c.Model)
  74. dblog.Fail2()
  75. } else {
  76. dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", linkstyle_modelDesc, c.Model)
  77. dblog.Success2()
  78. }
  79. return err
  80. }
  81. func (c *LinkStyleMgr) One() (T_data_link_style, error) {
  82. if c.Model.Id == 0 {
  83. return c.Model, errors.New("未指定id")
  84. }
  85. o := orm.NewOrm()
  86. err := o.Read(&c.Model)
  87. if err != nil {
  88. logger.Logger.Error(err)
  89. }
  90. return c.Model, err
  91. }
  92. //根据接线方式中指定的id删除检测任务
  93. func (c *LinkStyleMgr) Delete() (err error) {
  94. dblog := new(SystemLog)
  95. dblog.SetUserInfo(c.GetUserInfo())
  96. dblog.Audittype = enum.AuditType_link_style
  97. dblog.Logtype = enum.LogType_Delete
  98. dblog.Eventtype = enum.OptEventType_Bus
  99. dblog.Eventlevel = enum.OptEventLevel_Hight
  100. db := orm.NewOrm()
  101. if c.Model.Id > 0 {
  102. db.Read(&c.Model)
  103. _, err = db.Delete(&c.Model)
  104. }
  105. if err != nil {
  106. logger.Logger.Error(err)
  107. dblog.Description = fmt.Sprintf("删除%s%s失败:%s", linkstyle_modelDesc, c.Model.Name, err.Error())
  108. dblog.Fail2()
  109. } else {
  110. //同步清除关联的模型
  111. lsm := new(LinkStyleModelMgr)
  112. lsm.Model.LinkstyleId = c.Model.Id
  113. lsm.Delete()
  114. dblog.Description = fmt.Sprintf("删除%s%s成功", linkstyle_modelDesc, c.Model.Name)
  115. dblog.Success2()
  116. }
  117. return err
  118. }
  119. //根据接线方式中的指定过滤属性条件查询列表
  120. func (c *LinkStyleMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
  121. dblog := new(SystemLog)
  122. dblog.SetUserInfo(c.GetUserInfo())
  123. dblog.Audittype = enum.AuditType_link_style
  124. dblog.Logtype = enum.LogType_Query
  125. dblog.Eventtype = enum.OptEventType_Bus
  126. dblog.Eventlevel = enum.OptEventLevel_Low
  127. o := orm.NewOrm()
  128. sqlParamters := []interface{}{}
  129. sql := "select t.*,t1.name vol_level_name from t_data_link_style t left join global_const_code t1 on t.vol_level_id=t1.id where 1=1 "
  130. if c.Model.Id > 0 {
  131. sql += " and t.id=?"
  132. sqlParamters = append(sqlParamters, c.Model.Id)
  133. }
  134. if c.Model.VolLevelId > 0 {
  135. sql += " and t.vol_level_id=?"
  136. sqlParamters = append(sqlParamters, c.Model.VolLevelId)
  137. }
  138. limit := fmt.Sprintf(" order by t.id desc limit %d,%d", (pageno-1)*pagesize, pagesize)
  139. r := []orm.Params{}
  140. _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
  141. dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
  142. if err != nil {
  143. logger.Logger.Error(err, dblog.Description)
  144. dblog.Fail2()
  145. return nil, 0, err
  146. }
  147. dblog.Success2()
  148. total := []orm.Params{}
  149. _, err = o.Raw(strings.Replace(sql, "t.*,t1.name vol_level_name", "count(1) cnt", 1), sqlParamters).Values(&total)
  150. if err != nil {
  151. logger.Logger.Error(err)
  152. return nil, 0, err
  153. }
  154. totalCnt := 0
  155. if len(total) > 0 {
  156. totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
  157. }
  158. return r, totalCnt, err
  159. }