check_sys_model.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  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_model_defualt struct {
  14. Id int `orm:"pk"`
  15. ModelName string // '模型名称' ,
  16. AreaType int // '所属间隔类型ID' ,
  17. VolId int // '所属电压等级ID' ,
  18. LineLinkStyle int // '接线方式' ,
  19. IedTypes string // '包含的装置类型' ,
  20. RelationJson string // '关系定义内容' ,
  21. Cr int // '创建人' ,
  22. Ct string `orm:"-"` // '创建时间' ,
  23. Ur int // '更新人' ,
  24. Ut string `orm:"-"` // '更新时间'
  25. }
  26. //内置检测模型管理对象
  27. type SysCheckModelMgr struct {
  28. Model T_data_model_defualt
  29. DeviceBaseModel
  30. }
  31. var sysCheckModelDesc = "内置检测模型"
  32. func init() {
  33. orm.RegisterModel(new(T_data_model_defualt))
  34. }
  35. //保存检测模型信息
  36. func (c *SysCheckModelMgr) Save() (err error) {
  37. dblog := new(SystemLog)
  38. dblog.SetUserInfo(c.GetUserInfo())
  39. dblog.Audittype = enum.AuditType_check_model
  40. dblog.Logtype = enum.LogType_Insert
  41. dblog.Eventtype = enum.OptEventType_Bus
  42. dblog.Eventlevel = enum.OptEventLevel_Hight
  43. err = c.Delete()
  44. if err != nil {
  45. return err
  46. }
  47. db := orm.NewOrm()
  48. if c.Model.Id == 0 {
  49. c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
  50. _, err = db.Insert(&c.Model)
  51. } else {
  52. tmpObj, err := c.One()
  53. if err != nil {
  54. return err
  55. }
  56. c.Model.Cr = tmpObj.Cr
  57. c.Model.Ur, _ = strconv.Atoi(c.GetUserId())
  58. _, err = db.Update(&c.Model)
  59. }
  60. if err != nil {
  61. logger.Logger.Error(err)
  62. dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", sysCheckModelDesc, err.Error(), c.Model)
  63. dblog.Fail2()
  64. } else {
  65. dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", sysCheckModelDesc, c.Model)
  66. dblog.Success2()
  67. }
  68. return err
  69. }
  70. func (c *SysCheckModelMgr) One() (T_data_model_defualt, error) {
  71. if c.Model.Id == 0 {
  72. return c.Model, errors.New("未指定id")
  73. }
  74. o := orm.NewOrm()
  75. err := o.Read(&c.Model)
  76. if err != nil {
  77. logger.Logger.Error(err)
  78. }
  79. return c.Model, err
  80. }
  81. //根据model中指定的id删除
  82. func (c *SysCheckModelMgr) Delete() (err error) {
  83. dblog := new(SystemLog)
  84. dblog.SetUserInfo(c.GetUserInfo())
  85. dblog.Audittype = enum.AuditType_check_model
  86. dblog.Logtype = enum.LogType_Delete
  87. dblog.Eventtype = enum.OptEventType_Bus
  88. dblog.Eventlevel = enum.OptEventLevel_Hight
  89. db := orm.NewOrm()
  90. if c.Model.Id > 0 {
  91. db.Read(&c.Model)
  92. _, err = db.Delete(&c.Model)
  93. }
  94. if err != nil {
  95. logger.Logger.Error(err)
  96. dblog.Description = fmt.Sprintf("删除%s%s失败:%s", sysCheckModelDesc, c.Model.ModelName, err.Error())
  97. dblog.Fail2()
  98. } else {
  99. lsm := new(LinkStyleModelMgr)
  100. lsm.Model.ModelId = c.Model.Id
  101. lsm.Delete()
  102. dblog.Description = fmt.Sprintf("删除%s%s成功", sysCheckModelDesc, c.Model.ModelName)
  103. dblog.Success2()
  104. }
  105. return err
  106. }
  107. //根据model中的指定过滤属性条件查询列表
  108. func (c *SysCheckModelMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
  109. dblog := new(SystemLog)
  110. dblog.SetUserInfo(c.GetUserInfo())
  111. dblog.Audittype = enum.AuditType_check_model
  112. dblog.Logtype = enum.LogType_Query
  113. dblog.Eventtype = enum.OptEventType_Bus
  114. dblog.Eventlevel = enum.OptEventLevel_Low
  115. o := orm.NewOrm()
  116. sqlParamters := []interface{}{}
  117. sql := "select t.*,t1.name area_type_name,s1.name line_link_style_name,v1.name voltage_level_name from t_data_model_defualt t left join global_const_code t1 on t.area_type=t1.id and t1.parentcode='area_type' left join global_const_code v1 on t.voltage_level=v1.id and v1.parentcode='voltage_level' left join t_data_link_style s1 on t.line_link_style=s1.id where 1=1 "
  118. if c.Model.Id > 0 {
  119. sql += " and t.id=?"
  120. sqlParamters = append(sqlParamters, c.Model.Id)
  121. }
  122. if c.Model.VolId > 0 {
  123. sql += " and t.vol_id=?"
  124. sqlParamters = append(sqlParamters, c.Model.VolId)
  125. }
  126. if c.Model.LineLinkStyle > 0 {
  127. sql += " and t.line_link_style=?"
  128. sqlParamters = append(sqlParamters, c.Model.LineLinkStyle)
  129. }
  130. if c.Model.AreaType > 0 {
  131. sql += " and t.area_type=?"
  132. sqlParamters = append(sqlParamters, c.Model.AreaType)
  133. }
  134. if c.Model.ModelName != "" {
  135. sql += " and t.model_name like ?"
  136. sqlParamters = append(sqlParamters, "%"+c.Model.ModelName+"%")
  137. }
  138. limit := fmt.Sprintf(" order by t.ct 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 area_type_name,s1.name line_link_style_name,v1.name voltage_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. }