sql.go 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. package crontab
  2. import (
  3. "errors"
  4. "fmt"
  5. "kpt-pasture/model"
  6. "time"
  7. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  8. "gitee.com/xuyiping_admin/pkg/logger/zaplog"
  9. "gitee.com/xuyiping_admin/pkg/xerr"
  10. "go.uber.org/zap"
  11. "gorm.io/gorm"
  12. )
  13. func (e *Entry) FindPastureList() []*model.AppPastureList {
  14. res := make([]*model.AppPastureList, 0)
  15. if err := e.DB.Model(new(model.AppPastureList)).
  16. Where("is_show = ?", pasturePb.IsShow_Ok).
  17. Find(&res).Error; err != nil {
  18. zaplog.Error("FindPastureList error", zap.Any("err", err))
  19. return res
  20. }
  21. return res
  22. }
  23. func (e *Entry) GetCowById(cowId int64) (*model.Cow, error) {
  24. cowInfo := &model.Cow{}
  25. if err := e.DB.Model(new(model.Cow)).
  26. Where("id = ?", cowId).
  27. Where("admission_status = ?", pasturePb.AdmissionStatus_Admission).
  28. First(cowInfo).Error; err != nil {
  29. return nil, err
  30. }
  31. return cowInfo, nil
  32. }
  33. func (e *Entry) GetPenMapList() (map[int32]*model.Pen, error) {
  34. penList := make([]*model.Pen, 0)
  35. if err := e.DB.Where("is_delete = ?", pasturePb.IsShow_Ok).Find(&penList).Error; err != nil {
  36. return nil, xerr.WithStack(err)
  37. }
  38. penMap := make(map[int32]*model.Pen)
  39. for _, v := range penList {
  40. penMap[v.Id] = v
  41. }
  42. return penMap, nil
  43. }
  44. // GetBeforeThreeDaysCowEstrus 获取值得时间之前三天内最大发情记录
  45. func (e *Entry) GetBeforeThreeDaysCowEstrus(cowId int64, activeTime string) *model.EventEstrus {
  46. eventEstrus := &model.EventEstrus{}
  47. if err := e.DB.Model(new(model.EventEstrus)).
  48. Select("MAX(max_high) as max_high,cow_id,MAX(day_high) as day_high").
  49. Select("MAX(IF(result=1,3,result)) AS result").
  50. Where("cow_id = ?", cowId).
  51. Where("active_date >= ?", activeTime).
  52. First(eventEstrus).Error; err != nil {
  53. return eventEstrus
  54. }
  55. return eventEstrus
  56. }
  57. // GetTwoEstrus 判断最近50天内是否存在发情记录(发情等级>=2),如果18~25天@xadjust21,如果36~50天@xadjust42
  58. func (e *Entry) GetTwoEstrus(pastureId, cowId int64, startActiveTime, endActiveTime string) *CowEstrus {
  59. newCowEstrus := &CowEstrus{}
  60. if err := e.DB.Model(new(model.EventEstrus)).
  61. Select("cow_id,MAX(active_date) as active_date").
  62. Where("cow_id = ?", cowId).
  63. Where("pasture_id = ?", pastureId).
  64. Where("active_date BETWEEN ? AND ?", startActiveTime, endActiveTime).
  65. Where("level >= ?", pasturePb.EstrusLevel_Middle).
  66. First(newCowEstrus).Error; err != nil {
  67. return newCowEstrus
  68. }
  69. return newCowEstrus
  70. }
  71. func (e *Entry) FindCowInfoByNeckRingNumber(neckRingNumber string) *model.Cow {
  72. res := &model.Cow{}
  73. if err := e.DB.Model(new(model.Cow)).
  74. Where("neck_ring_number = ?", neckRingNumber).
  75. Where("admission_status = ?", pasturePb.AdmissionStatus_Admission).
  76. First(res).Error; err != nil {
  77. return nil
  78. }
  79. return res
  80. }
  81. func (e *Entry) IsExistEventEstrus(pastureId, cowId int64) *model.EventEstrus {
  82. res := &model.EventEstrus{}
  83. if err := e.DB.Model(new(model.EventEstrus)).
  84. Where("cow_id = ?", cowId).
  85. Where("pasture_id = ?", pastureId).
  86. Where("expose_estrus_type = ?", pasturePb.ExposeEstrusType_Neck_Ring).
  87. Where("is_show = ?", pasturePb.IsShow_Ok).
  88. Order("id DESC").
  89. First(res).Error; err != nil {
  90. return nil
  91. }
  92. return res
  93. }
  94. func (e *Entry) IsExistNeckActiveHabit(neckRingNumber, heatDate string, frameId int32) (*model.NeckActiveHabit, int64) {
  95. count := int64(0)
  96. neckActiveHabit := &model.NeckActiveHabit{}
  97. if err := e.DB.Model(new(model.NeckActiveHabit)).
  98. Where("neck_ring_number = ?", neckRingNumber).
  99. Where("heat_date = ?", heatDate).
  100. Where("frameid = ?", frameId).
  101. Count(&count).
  102. First(neckActiveHabit).Error; err != nil {
  103. return nil, 0
  104. }
  105. return neckActiveHabit, count
  106. }
  107. func (e *Entry) GetSystemConfigure(pastureId int64) ([]*model.SystemConfigure, error) {
  108. res := make([]*model.SystemConfigure, 0)
  109. if err := e.DB.Model(new(model.SystemConfigure)).
  110. Where("pasture_id = ?", pastureId).
  111. Where("is_show = ?", pasturePb.IsShow_Ok).
  112. Find(&res).Error; err != nil {
  113. return nil, xerr.WithStack(err)
  114. }
  115. return res, nil
  116. }
  117. func (e *Entry) GetCowInfoByNeckRingNumber(pastureId int64, neckRingNumber string) *model.Cow {
  118. res := &model.Cow{}
  119. if err := e.DB.Model(new(model.Cow)).
  120. Where("pasture_id = ?", pastureId).
  121. Where("neck_ring_number = ?", neckRingNumber).
  122. Where("admission_status = ?", pasturePb.AdmissionStatus_Admission).
  123. First(res).Error; err != nil {
  124. return nil
  125. }
  126. return res
  127. }
  128. // GetMinIdByHeatDate 获取最小的id
  129. func (e *Entry) GetMinIdByHeatDate(heatDate string, defaultId int64) (int64, error) {
  130. xMinId := struct {
  131. Id int64
  132. }{}
  133. if err := e.DB.Model(new(model.NeckActiveHabit)).
  134. Select("MIN(id) as id").
  135. Where("heat_date = ?", heatDate).
  136. First(&xMinId).Error; err != nil {
  137. if errors.Is(err, gorm.ErrRecordNotFound) {
  138. xMinId.Id = defaultId
  139. } else {
  140. return 0, xerr.WithStack(err)
  141. }
  142. }
  143. return xMinId.Id, nil
  144. }
  145. func (e *Entry) FindFirstFilter(pastureId int64, neckRingNumber, heatDate string, frameId int32) *FirstFilterData {
  146. firstFilterData := &FirstFilterData{}
  147. if err := e.DB.Model(new(model.NeckActiveHabit)).
  148. Select("neck_ring_number", "filter_high", "filter_rumina", "filter_chew").
  149. Where("neck_ring_number = ?", neckRingNumber).
  150. Where("heat_date = ?", heatDate).
  151. Where("frameid = ?", frameId).
  152. Where("pasture_id = ?", pastureId).
  153. First(firstFilterData).Error; err != nil {
  154. zaplog.Error("FirstFilterUpdate",
  155. zap.Any("err", err),
  156. zap.Any("NeckRingNumber", neckRingNumber),
  157. zap.Any("heatDate", heatDate),
  158. zap.Any("frameId", frameId),
  159. )
  160. }
  161. return firstFilterData
  162. }
  163. func (e *Entry) FindWeekHabitData(pastureId int64, neckRingNumber, heatDate string, frameid int32, xToday *XToday) *WeekHabit {
  164. beginDayDate, _ := time.Parse(model.LayoutDate2, heatDate)
  165. before7DayDate := beginDayDate.AddDate(0, 0, -7).Format(model.LayoutDate2)
  166. before1DayDate := beginDayDate.AddDate(0, 0, -1).Format(model.LayoutDate2)
  167. weekHabitData := &WeekHabit{}
  168. if err := e.DB.Model(new(model.NeckActiveHabit)).
  169. Select(
  170. "neck_ring_number",
  171. "IF(COUNT(1)>=3, ROUND((SUM(filter_high) -MIN(filter_high) -MAX(filter_high))/ABS(COUNT(1) -2),0), -1) as week_high_habit",
  172. "IF(COUNT(1)>=3, ROUND((SUM(filter_rumina) -MIN(filter_rumina) -MAX(filter_rumina))/ABS(COUNT(1) -2),0), -1) as week_rumina_habit",
  173. "IF(COUNT(1)>=3, ROUND((SUM(filter_chew) -MIN(filter_chew) -MAX(filter_chew))/ABS(COUNT(1) -2),0), -1) as week_chew_habit",
  174. "ROUND(AVG(intake),0) as week_intake_habit",
  175. "ROUND(AVG(inactive),0) as week_inactive_habit",
  176. ).Where("pasture_id = ?", pastureId).
  177. Where("heat_date BETWEEN ? AND ?", before7DayDate, before1DayDate).
  178. Where("neck_ring_number = ? ", neckRingNumber).
  179. Where("frameid = ?", frameid).
  180. Where(e.DB.Where("high > ?", xToday.High).Or("rumina >= ?", xToday.Rumina)).
  181. Group("neck_ring_number").First(weekHabitData).Error; err != nil {
  182. zaplog.Error("WeeklyActiveAvgUpdate-1",
  183. zap.Any("error", err),
  184. zap.Any("neckRingNumber", neckRingNumber),
  185. zap.Any("frameId", frameid),
  186. zap.Any("heatDate", heatDate),
  187. zap.Any("xToday", xToday),
  188. )
  189. }
  190. return weekHabitData
  191. }
  192. func (e *Entry) FindSumHabitData(pastureId int64, neckRingNumber, heatDate string, frameid int32, xToday *XToday) *SumHabit {
  193. beginDayDate, _ := time.Parse(model.LayoutDate2, heatDate)
  194. before1DayDate := beginDayDate.AddDate(0, 0, -1).Format(model.LayoutDate2)
  195. activeTime := fmt.Sprintf("%s %02d:00:00", heatDate, frameid*2+1)
  196. activeStartTimeParse, _ := time.Parse(model.LayoutTime, activeTime)
  197. activeStartTime := activeStartTimeParse.Add(-23 * time.Hour).Format(model.LayoutTime)
  198. // 累计24小时数值
  199. sumHabitData := &SumHabit{}
  200. if err := e.DB.Model(new(model.NeckActiveHabit)).
  201. Select(
  202. "neck_ring_number",
  203. "IF(COUNT(1)>6, ROUND(AVG(filter_rumina)*12,0), 0) as sum_rumina",
  204. "IF(COUNT(1)>6, ROUND(AVG(intake)*12,0), 0) as sum_intake",
  205. "IF(COUNT(1)>6, ROUND(AVG(inactive)*12,0), 0) as sum_inactive",
  206. "IF(COUNT(1)>6, ROUND(AVG(active)*12,0), 0) as sum_active",
  207. "MAX(change_filter) as sum_max_high",
  208. fmt.Sprintf("MIN(IF(change_filter > %d, change_filter, %d)) as sum_min_high", model.DefaultChangeFilter, model.InitChangeFilter),
  209. fmt.Sprintf("MIN( CASE WHEN filter_chew > %d THEN filter_chew WHEN filter_rumina >= %d THEN filter_rumina ELSE 0 END) as sum_min_chew", model.DefaultChangeFilter, model.DefaultRuminaFilter),
  210. ).
  211. Where("pasture_id = ?", pastureId).
  212. Where("heat_date BETWEEN ? AND ?", before1DayDate, beginDayDate).
  213. Where("active_time BETWEEN ? AND ?", activeStartTime, activeTime).
  214. Where(e.DB.Where("high > ?", xToday.High).Or("rumina >= ?", xToday.Rumina)).
  215. Where("neck_ring_number = ? AND frameid = ?", neckRingNumber, frameid).
  216. Group("neck_ring_number").First(sumHabitData).Error; err != nil {
  217. zaplog.Error("WeeklyActiveAvgUpdate-2",
  218. zap.Any("error", err),
  219. zap.Any("neckRingNumber", neckRingNumber),
  220. zap.Any("frameId", frameid),
  221. zap.Any("heatDate", heatDate),
  222. zap.Any("xToday", xToday),
  223. )
  224. }
  225. return sumHabitData
  226. }
  227. func (e *Entry) FindBefore3DaysNeckActiveHabit(pastureId int64, neckRingNumber, heatDate string, frameid int32) *model.NeckActiveHabit {
  228. before3DaysNeckActiveHabit := &model.NeckActiveHabit{}
  229. beginDayDate, _ := time.Parse(model.LayoutDate2, heatDate)
  230. before3DayDate := beginDayDate.AddDate(0, 0, -3).Format(model.LayoutDate2)
  231. if err := e.DB.Model(new(model.NeckActiveHabit)).
  232. Select("sum_rumina", "sum_intake").
  233. Where("pasture_id = ?", pastureId).
  234. Where("neck_ring_number = ?", neckRingNumber).
  235. Where("heat_date = ?", before3DayDate).
  236. Where("frameid = ? ", frameid).
  237. First(before3DaysNeckActiveHabit).Error; err != nil {
  238. zaplog.Error("WeeklyActiveAvgUpdate-3",
  239. zap.Any("error", err),
  240. zap.Any("neckRingNumber", neckRingNumber),
  241. zap.Any("frameId", frameid),
  242. zap.Any("heatDate", heatDate),
  243. )
  244. }
  245. return before3DaysNeckActiveHabit
  246. }