Logs.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. package System
  2. import (
  3. "Cold_Api/logs"
  4. "encoding/json"
  5. "github.com/beego/beego/v2/adapter/orm"
  6. orm2 "github.com/beego/beego/v2/client/orm"
  7. "time"
  8. )
  9. type Logs struct {
  10. Id int `orm:"column(ID);size(11);auto;pk"`
  11. Logs_class string `orm:"size(256);null"` //
  12. Logs_Title string `orm:"size(256);null"` // 标题
  13. Logs_Txt string `orm:"type(text);null"` // 详情
  14. CreateTime time.Time `orm:"column(create_time);type(timestamp);null;auto_now_add"` //auto_now 每次 model 保存时都会对时间自动更新
  15. UpdateTime time.Time `orm:"column(update_time);type(timestamp);null;auto_now"` //auto_now_add 第一次保存时才设置时间
  16. }
  17. func (t *Logs) TableName() string {
  18. return "logs" // 数据库名称 // ************** 替换 FormulaList **************
  19. }
  20. func init() {
  21. //注册模型
  22. orm.RegisterModel(new(Logs))
  23. }
  24. // 添加 System.Add_Logs("MqttServer","参数请求 [Rt_Parameter]","base")
  25. func Add_Logs(Logs_class string, Logs_Title string, Logs_Txt string) {
  26. o := orm.NewOrm()
  27. m := Logs{Logs_class: Logs_class, Logs_Title: Logs_Title, Logs_Txt: Logs_Txt}
  28. _, err := o.Insert(&m)
  29. if err != nil {
  30. logs.Error("Add_Logs", err)
  31. }
  32. }
  33. func Add_Logs_T(Logs_class string, Logs_Title string, Logs_Txt_T interface{}) {
  34. o := orm.NewOrm()
  35. jsonStu, err := json.Marshal(Logs_Txt_T)
  36. if err != nil {
  37. logs.Error("Add_UserLogs_T JSON ,err=", err)
  38. }
  39. m := Logs{Logs_class: Logs_class, Logs_Title: Logs_Title, Logs_Txt: string(jsonStu)}
  40. _, err = o.Insert(&m)
  41. if err != nil {
  42. logs.Error("Add_Logs_T", err)
  43. }
  44. }
  45. // 获取列表
  46. func Read_Logs_ALL(Logs_class string, page int, page_z int) (r []Logs, cnt int64) {
  47. o := orm.NewOrm()
  48. // 也可以直接使用 Model 结构体作为表名
  49. qs := o.QueryTable(new(Logs))
  50. var offset int64
  51. if page <= 1 {
  52. offset = 0
  53. } else {
  54. offset = int64((page - 1) * page_z)
  55. }
  56. cond := orm.NewCondition()
  57. cond1 := cond
  58. if len(Logs_class) > 0 {
  59. cond1 = cond1.And("Logs_class", Logs_class)
  60. }
  61. _, err := qs.Limit(page_z, offset).SetCond((*orm2.Condition)(cond1)).OrderBy("Id").All(&r)
  62. if err != nil {
  63. logs.Error("Read_Logs_ALL", err)
  64. return
  65. }
  66. cnt, err = qs.SetCond((*orm2.Condition)(cond1)).Count()
  67. if err != nil {
  68. logs.Error("Read_Logs_ALL Count", err)
  69. return
  70. }
  71. return r, cnt
  72. }
  73. type CLASS_lists struct {
  74. Logs_class string
  75. }
  76. // 获取列表
  77. func Read_Logs_Class() (lists orm2.ParamsList) {
  78. o := orm.NewOrm()
  79. var pl_lists orm2.ParamsList
  80. _, err := o.Raw("SELECT DISTINCT logs_class FROM Logs LIMIT 0,1000").ValuesFlat(&pl_lists)
  81. if err != nil {
  82. logs.Error("Read_Logs_Class", err)
  83. }
  84. return pl_lists
  85. }