GAAS GFrame项目web后台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

215 lines
9.7 KiB

  1. package models
  2. import (
  3. "LAPP_GAAS_GFrame_BACKEND/db"
  4. "LAPP_GAAS_GFrame_BACKEND/utils"
  5. "errors"
  6. "fmt"
  7. "xorm.io/core"
  8. )
  9. //日模型
  10. type Daymodel struct {
  11. Finr int `xorm:"pk comment('工厂号') Int" json:"daymodel-finr"`
  12. Daymodelid int `xorm:"pk comment('日模型ID') Int" json:"daymodel-daymodelid"`
  13. Descr string `xorm:"comment('描述') VARCHAR(30)" json:"daymodel-descr"`
  14. Abrev string `xorm:"comment('简写') VARCHAR(8)" json:"daymodel-abrev"`
  15. Color string `xorm:"comment('颜色') VARCHAR(8)" json:"daymodel-color"`
  16. S1Activ int `xorm:"comment('激活班次1') INT" json:"daymodel-s1_activ"`
  17. S2Activ int `xorm:"comment('激活班次2') INT" json:"daymodel-s2_activ"`
  18. S3Activ int `xorm:"comment('激活班次3') INT" json:"daymodel-s3_activ"`
  19. S4Activ int `xorm:"comment('激活班次4') INT" json:"daymodel-s4_activ"`
  20. S1Beg string `xorm:"comment('班次1开始') VARCHAR(5)" json:"daymodel-s1_beg"`
  21. S1End string `xorm:"comment('班次1结束') VARCHAR(5)" json:"daymodel-s1_end"`
  22. S1Len int `xorm:"comment('班次1长度') INT" json:"daymodel-s1_len"`
  23. S2Beg string `xorm:"comment('班次2开始') VARCHAR(5)" json:"daymodel-s2_beg"`
  24. S2End string `xorm:"comment('班次2结束') VARCHAR(5)" json:"daymodel-s2_end"`
  25. S2Len int `xorm:"comment('班次2长度') VARCHAR(5)" json:"daymodel-s2_len"`
  26. S3Beg string `xorm:"comment('班次3开始') VARCHAR(5)" json:"daymodel-s3_beg"`
  27. S3End string `xorm:"comment('班次3结束') VARCHAR(5)" json:"daymodel-s3_end"`
  28. S3Len int `xorm:"comment('班次3长度') VARCHAR(5)" json:"daymodel-s3_len"`
  29. S4Beg string `xorm:"comment('班次4开始') VARCHAR(5)" json:"daymodel-s4_beg"`
  30. S4End string `xorm:"comment('班次4结束') VARCHAR(5)" json:"daymodel-s4_end"`
  31. S4Len int `xorm:"comment('班次4长度') INT" json:"daymodel-s4_len"`
  32. DmLen int `xorm:"comment('Dm长度') INT" json:"daymodel-dm_len"`
  33. S1B1Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s1_b1_beg"`
  34. S1B1End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s1_b1_end"`
  35. S1B2Beg string `xorm:"comment('中断2开始') VARCHAR(5)" json:"daymodel-s1_b2_beg"`
  36. S1B2End string `xorm:"comment('中断2结束') VARCHAR(5)" json:"daymodel-s1_b2_end"`
  37. S1B3Beg string `xorm:"comment('中断3开始') VARCHAR(5)" json:"daymodel-s1_b3_beg"`
  38. S1B3End string `xorm:"comment('中断3结束') VARCHAR(5)" json:"daymodel-s1_b3_end"`
  39. S1B4Beg string `xorm:"comment('中断4开始') VARCHAR(5)" json:"daymodel-s1_b4_beg"`
  40. S1B4End string `xorm:"comment('中断4结束') VARCHAR(5)" json:"daymodel-s1_b4_end"`
  41. S1B5Beg string `xorm:"comment('中断5开始') VARCHAR(5)" json:"daymodel-s1_b5_beg"`
  42. S1B5End string `xorm:"comment('中断5结束') VARCHAR(5)" json:"daymodel-s1_b5_end"`
  43. S2B1Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s2_b1_beg"`
  44. S2B1End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s2_b1_end"`
  45. S2B2Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s2_b2_beg"`
  46. S2B2End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s2_b2_end"`
  47. S2B3Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s2_b3_beg"`
  48. S2B3End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s2_b3_end"`
  49. S2B4Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s2_b4_beg"`
  50. S2B4End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s2_b4_end"`
  51. S2B5Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s2_b5_beg"`
  52. S2B5End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s2_b5_end"`
  53. S3B1Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s3_b1_beg"`
  54. S3B1End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s3_b1_end"`
  55. S3B2Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s3_b2_beg"`
  56. S3B2End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s3_b2_end"`
  57. S3B3Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s3_b3_beg"`
  58. S3B3End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s3_b3_end"`
  59. S3B4Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s3_b4_beg"`
  60. S3B4End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s3_b4_end"`
  61. S3B5Beg string `xorm:"comment('中断1开始') VARCHAR(5)" json:"daymodel-s3_b5_beg"`
  62. S3B5End string `xorm:"comment('中断1结束') VARCHAR(5)" json:"daymodel-s3_b5_end"`
  63. Lastmodif string `xorm:"comment('最近一次更改时间') VARCHAR(14)" json:"daymodel-lastmodif"`
  64. Lastuser string `xorm:"comment('最近一次更改人') VARCHAR(20)" json:"daymodel-lastuser"`
  65. Credatuz string `xorm:"comment('创建时间') VARCHAR(14)" json:"daymodel-credatuz"`
  66. }
  67. func (t *Daymodel) TableName() string {
  68. return "daymodel"
  69. }
  70. // 清除string字段的右侧空格
  71. func (t *Daymodel) Clipped() {
  72. utils.TrimStruct(t, *t)
  73. }
  74. //增
  75. func (t *Daymodel) Add() error {
  76. e := db.Eloquent.Master()
  77. countrole := new(Daymodel)
  78. affw, err := e.Table("daymodel").ID(core.PK{t.Finr, t.Daymodelid}).Count(countrole)
  79. if err != nil {
  80. return err
  81. }
  82. if affw > 0 {
  83. return errors.New("数据已经存在!")
  84. }
  85. t.S1Len, _ = utils.Timelen(t.S1End, t.S1Beg)
  86. t.S2Len, _ = utils.Timelen(t.S2End, t.S2Beg)
  87. t.S3Len, _ = utils.Timelen(t.S3End, t.S3Beg)
  88. s1_b1_len, _ := utils.Timelen(t.S1B1End, t.S1B1Beg)
  89. s1_b2_len, _ := utils.Timelen(t.S1B2End, t.S1B2Beg)
  90. s1_b3_len, _ := utils.Timelen(t.S1B3End, t.S1B3Beg)
  91. s1_b4_len, _ := utils.Timelen(t.S1B4End, t.S1B4Beg)
  92. s1_b5_len, _ := utils.Timelen(t.S1B5End, t.S1B5Beg)
  93. s2_b1_len, _ := utils.Timelen(t.S2B1End, t.S2B1Beg)
  94. s2_b2_len, _ := utils.Timelen(t.S2B2End, t.S2B2Beg)
  95. s2_b3_len, _ := utils.Timelen(t.S2B3End, t.S2B3Beg)
  96. s2_b4_len, _ := utils.Timelen(t.S2B4End, t.S2B4Beg)
  97. s2_b5_len, _ := utils.Timelen(t.S2B5End, t.S2B5Beg)
  98. s3_b1_len, _ := utils.Timelen(t.S3B1End, t.S3B1Beg)
  99. s3_b2_len, _ := utils.Timelen(t.S3B2End, t.S3B2Beg)
  100. s3_b3_len, _ := utils.Timelen(t.S3B3End, t.S3B3Beg)
  101. s3_b4_len, _ := utils.Timelen(t.S3B4End, t.S3B4Beg)
  102. s3_b5_len, _ := utils.Timelen(t.S3B5End, t.S3B5Beg)
  103. t.DmLen = (t.S1Len - s1_b1_len - s1_b2_len - s1_b3_len - s1_b4_len - s1_b5_len) + (t.S2Len - s2_b1_len - s2_b2_len - s2_b3_len - s2_b4_len - s2_b5_len) + (t.S3Len - s3_b1_len - s3_b2_len - s3_b3_len - s3_b4_len - s3_b5_len)
  104. _, err = e.Table("daymodel").Insert(t)
  105. if err != nil {
  106. fmt.Printf("err is :%v", err)
  107. return err
  108. }
  109. return nil
  110. }
  111. //删
  112. func (t *Daymodel) Del() bool {
  113. e := db.Eloquent.Master()
  114. _, err := e.ID(core.PK{t.Finr, t.Daymodelid}).Delete(&Daymodel{})
  115. if err != nil {
  116. return false
  117. }
  118. return true
  119. }
  120. //改
  121. func (t *Daymodel) Update() bool {
  122. e := db.Eloquent.Master()
  123. t.S1Len, _ = utils.Timelen(t.S1End, t.S1Beg)
  124. t.S2Len, _ = utils.Timelen(t.S2End, t.S2Beg)
  125. t.S3Len, _ = utils.Timelen(t.S3End, t.S3Beg)
  126. s1_b1_len, _ := utils.Timelen(t.S1B1End, t.S1B1Beg)
  127. s1_b2_len, _ := utils.Timelen(t.S1B2End, t.S1B2Beg)
  128. s1_b3_len, _ := utils.Timelen(t.S1B3End, t.S1B3Beg)
  129. s1_b4_len, _ := utils.Timelen(t.S1B4End, t.S1B4Beg)
  130. s1_b5_len, _ := utils.Timelen(t.S1B5End, t.S1B5Beg)
  131. s2_b1_len, _ := utils.Timelen(t.S2B1End, t.S2B1Beg)
  132. s2_b2_len, _ := utils.Timelen(t.S2B2End, t.S2B2Beg)
  133. s2_b3_len, _ := utils.Timelen(t.S2B3End, t.S2B3Beg)
  134. s2_b4_len, _ := utils.Timelen(t.S2B4End, t.S2B4Beg)
  135. s2_b5_len, _ := utils.Timelen(t.S2B5End, t.S2B5Beg)
  136. s3_b1_len, _ := utils.Timelen(t.S3B1End, t.S3B1Beg)
  137. s3_b2_len, _ := utils.Timelen(t.S3B2End, t.S3B2Beg)
  138. s3_b3_len, _ := utils.Timelen(t.S3B3End, t.S3B3Beg)
  139. s3_b4_len, _ := utils.Timelen(t.S3B4End, t.S3B4Beg)
  140. s3_b5_len, _ := utils.Timelen(t.S3B5End, t.S3B5Beg)
  141. t.DmLen = (t.S1Len - s1_b1_len - s1_b2_len - s1_b3_len - s1_b4_len - s1_b5_len) + (t.S2Len - s2_b1_len - s2_b2_len - s2_b3_len - s2_b4_len - s2_b5_len) + (t.S3Len - s3_b1_len - s3_b2_len - s3_b3_len - s3_b4_len - s3_b5_len)
  142. _, err := e.ID(core.PK{t.Finr, t.Daymodelid}).Update(t)
  143. if err != nil {
  144. return false
  145. }
  146. return true
  147. }
  148. //查
  149. func (t *Daymodel) SelectOne() (Daymodel, error) {
  150. e := db.Eloquent.Master()
  151. var data Daymodel
  152. _, err := e.ID(core.PK{t.Finr, t.Daymodelid}).Get(&data)
  153. if err != nil {
  154. return data, err
  155. }
  156. return data, nil
  157. }
  158. //分页
  159. func (t *Daymodel) GetPage(pageSize int, pageIndex int) ([]Daymodel, int, error) {
  160. data := make([]Daymodel, 0)
  161. e := db.Eloquent.Master()
  162. table := e.Table("daymodel").Where("finr = ? ", t.Finr)
  163. where := "where finr = " + "'" + utils.ValueToString(t.Finr, "") + "'"
  164. if t.Daymodelid > 0 {
  165. table = table.And("daymodelid = ?", t.Daymodelid)
  166. where += " and daymodelid = " + "'" + utils.ValueToString(t.Daymodelid, "") + "'"
  167. }
  168. Offset := (pageIndex - 1) * pageSize
  169. err := e.SQL("SELECT TOP " + utils.ValueToString(pageSize, "") + " daymodel.* FROM daymodel " + where + " AND (convert(varchar(10),finr)+convert(varchar(40),daymodelid) NOT IN (SELECT TOP " + utils.ValueToString(Offset, "") + " convert(varchar(10),finr)+convert(varchar(40),daymodelid) FROM daymodel " + where + " ORDER BY credatuz DESC)) ORDER BY credatuz DESC").Find(&data)
  170. pcount := new(Daymodel)
  171. count, err := table.Count(pcount)
  172. if err != nil {
  173. return data, 0, err
  174. }
  175. for k, _ := range data {
  176. data[k].Clipped()
  177. }
  178. return data, int(count), nil
  179. }
  180. type DayModelData struct {
  181. Daymodelid int `json:"daymodelid"`
  182. Descr string `json:"descr"`
  183. Abrev string `json:"abrev"`
  184. Color string `json:"color"`
  185. }
  186. func (t *Daymodel) SelectArr() ([]DayModelData, error) {
  187. e := db.Eloquent.Master()
  188. var data []DayModelData
  189. err := e.Table("daymodel").Where("finr = ?", t.Finr).Find(&data)
  190. if err != nil {
  191. return data, err
  192. }
  193. return data, nil
  194. }