link_style_area.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  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_model struct {
  14. Id int `orm:"pk"`
  15. LinkstyleId int // '接线方式ID' ,
  16. ModelId int // '内置模型ID' ,
  17. Cr int // '创建人' ,
  18. Ct string `orm:"-"` // '创建时间' ,
  19. Ur int // '更新人' ,
  20. Ut string `orm:"-"` // '更新时间'
  21. }
  22. //接线方式-模型管理对象
  23. type LinkStyleModelMgr struct {
  24. Model T_data_link_style_model
  25. DeviceBaseModel
  26. }
  27. var linkstylearea_modelDesc = "接线方式-模型关联"
  28. func init() {
  29. orm.RegisterModel(new(T_data_link_style_model))
  30. }
  31. //保存接线方式信息
  32. func (c *LinkStyleModelMgr) Save() (err error) {
  33. dblog := new(SystemLog)
  34. dblog.SetUserInfo(c.GetUserInfo())
  35. dblog.Audittype = enum.AuditType_link_style
  36. dblog.Logtype = enum.LogType_Insert
  37. dblog.Eventtype = enum.OptEventType_Bus
  38. dblog.Eventlevel = enum.OptEventLevel_Hight
  39. db := orm.NewOrm()
  40. if c.Model.Id == 0 {
  41. c.Model.Cr, _ = strconv.Atoi(c.GetUserId())
  42. _, err = db.Insert(&c.Model)
  43. } else {
  44. c.Model.Ur, _ = strconv.Atoi(c.GetUserId())
  45. _, err = db.Update(&c.Model)
  46. }
  47. if err != nil {
  48. logger.Logger.Error(err)
  49. dblog.Description = fmt.Sprintf("保存%s信息失败:%s,操作数据:%+v", linkstylearea_modelDesc, err.Error(), c.Model)
  50. dblog.Fail2()
  51. } else {
  52. dblog.Description = fmt.Sprintf("保存%s信息成功,操作数据:%+v", linkstylearea_modelDesc, c.Model)
  53. dblog.Success2()
  54. }
  55. return err
  56. }
  57. func (c *LinkStyleModelMgr) One() (T_data_link_style_model, error) {
  58. if c.Model.Id == 0 {
  59. return c.Model, errors.New("未指定id")
  60. }
  61. o := orm.NewOrm()
  62. err := o.Read(&c.Model)
  63. if err != nil {
  64. logger.Logger.Error(err)
  65. }
  66. return c.Model, err
  67. }
  68. //根据model中指定的id删除检
  69. func (c *LinkStyleModelMgr) Delete() (err error) {
  70. dblog := new(SystemLog)
  71. dblog.SetUserInfo(c.GetUserInfo())
  72. dblog.Audittype = enum.AuditType_link_style
  73. dblog.Logtype = enum.LogType_Delete
  74. dblog.Eventtype = enum.OptEventType_Bus
  75. dblog.Eventlevel = enum.OptEventLevel_Hight
  76. db := orm.NewOrm()
  77. if c.Model.Id > 0 {
  78. db.Read(&c.Model)
  79. _, err = db.Delete(&c.Model)
  80. }
  81. if c.Model.LinkstyleId > 0 && c.Model.ModelId > 0 {
  82. linkstylearea_modelDesc = linkstylearea_modelDesc + fmt.Sprintf("[模型ID=%d]", c.Model.ModelId)
  83. _, err = db.Raw("delete from t_data_link_style_model where linkstyle_id=? and model_id=?", c.Model.LinkstyleId, c.Model.ModelId).Exec()
  84. } else {
  85. if c.Model.LinkstyleId > 0 {
  86. linkstylearea_modelDesc = linkstylearea_modelDesc + fmt.Sprintf("[接线方式ID=%d]", c.Model.LinkstyleId)
  87. _, err = db.Raw("delete from t_data_link_style_model where linkstyle_id=?", c.Model.LinkstyleId).Exec()
  88. }
  89. if c.Model.ModelId > 0 {
  90. linkstylearea_modelDesc = linkstylearea_modelDesc + fmt.Sprintf("[模型ID=%d]", c.Model.ModelId)
  91. _, err = db.Raw("delete from t_data_link_style_model where model_id=?", c.Model.ModelId).Exec()
  92. }
  93. }
  94. if err != nil {
  95. logger.Logger.Error(err)
  96. dblog.Description = fmt.Sprintf("删除%s失败:%s", linkstylearea_modelDesc, err.Error())
  97. dblog.Fail2()
  98. } else {
  99. dblog.Description = fmt.Sprintf("删除%s成功", linkstylearea_modelDesc)
  100. dblog.Success2()
  101. }
  102. return err
  103. }
  104. //根据model中的指定过滤属性条件查询列表
  105. func (c *LinkStyleModelMgr) List(pageno, pagesize int) ([]orm.Params, int, error) {
  106. dblog := new(SystemLog)
  107. dblog.SetUserInfo(c.GetUserInfo())
  108. dblog.Audittype = enum.AuditType_link_style
  109. dblog.Logtype = enum.LogType_Query
  110. dblog.Eventtype = enum.OptEventType_Bus
  111. dblog.Eventlevel = enum.OptEventLevel_Low
  112. o := orm.NewOrm()
  113. sqlParamters := []interface{}{}
  114. sql := "select t.*,t1.model_name from t_data_link_style_model t,t_data_model_defualt t1 where t.model_id=t1.id "
  115. if c.Model.Id > 0 {
  116. sql += " and t.id=?"
  117. sqlParamters = append(sqlParamters, c.Model.Id)
  118. }
  119. if c.Model.LinkstyleId > 0 {
  120. sql += " and t.linkstyle_id=?"
  121. sqlParamters = append(sqlParamters, c.Model.LinkstyleId)
  122. }
  123. limit := fmt.Sprintf(" order by t.id desc limit %d,%d", (pageno-1)*pagesize, pagesize)
  124. r := []orm.Params{}
  125. _, err := o.Raw(sql+limit, sqlParamters).Values(&r)
  126. dblog.Description = fmt.Sprintf("SQL:%s 参数:%+v", sql+limit, sqlParamters)
  127. if err != nil {
  128. logger.Logger.Error(err, dblog.Description)
  129. dblog.Fail2()
  130. return nil, 0, err
  131. }
  132. dblog.Success2()
  133. total := []orm.Params{}
  134. _, err = o.Raw(strings.Replace(sql, "t.*", "count(1) cnt", 1), sqlParamters).Values(&total)
  135. if err != nil {
  136. logger.Logger.Error(err)
  137. return nil, 0, err
  138. }
  139. totalCnt := 0
  140. if len(total) > 0 {
  141. totalCnt, _ = strconv.Atoi(tools.IsEmpty(total[0]["cnt"]))
  142. }
  143. return r, totalCnt, err
  144. }