dashboard.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571
  1. package backend
  2. import (
  3. "context"
  4. "errors"
  5. "fmt"
  6. "kpt-pasture/model"
  7. "kpt-pasture/util"
  8. "net/http"
  9. "regexp"
  10. "strconv"
  11. "strings"
  12. "time"
  13. "gorm.io/gorm"
  14. "gitee.com/xuyiping_admin/pkg/logger/zaplog"
  15. "gitee.com/xuyiping_admin/pkg/xerr"
  16. "go.uber.org/zap"
  17. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  18. )
  19. func (s *StoreEntry) NeckRingWarning(ctx context.Context) (*pasturePb.IndexNeckRingResponse, error) {
  20. userModel, err := s.GetUserModel(ctx)
  21. if err != nil {
  22. return nil, xerr.WithStack(err)
  23. }
  24. var count int64
  25. neckRingEstrusList := make([]*model.NeckRingEstrusWarning, 0)
  26. estrusWarningLevelItems := map[int32]int32{
  27. int32(pasturePb.EstrusLevel_Low): 0,
  28. int32(pasturePb.EstrusLevel_Middle): 0,
  29. int32(pasturePb.EstrusLevel_High): 0,
  30. }
  31. pref, err := s.EstrusWarningQuery(ctx, userModel.AppPasture.Id)
  32. if err != nil {
  33. return nil, xerr.Customf("系统错误!")
  34. }
  35. if err = pref.Order("a.level DESC").
  36. Count(&count).
  37. Find(&neckRingEstrusList).Error; err != nil {
  38. return nil, xerr.WithStack(err)
  39. }
  40. countEstrusWarning := 0
  41. nowTime := time.Now().Local()
  42. optimumMating := map[string]int32{
  43. "front": 0,
  44. "middle": 0,
  45. "behind": 0,
  46. }
  47. for _, v := range neckRingEstrusList {
  48. estrusWarningLevelItems[int32(v.Level)] += 1
  49. countEstrusWarning += 1
  50. cowInfo, _ := s.GetCowInfoByEarNumber(ctx, userModel.AppPasture.Id, v.EarNumber)
  51. pzHour := v.CalculatePzHour(cowInfo.Lact)
  52. optimumMatingStartTime := pzHour.Add(-4 * time.Hour)
  53. optimumMatingEndTime := pzHour.Add(4 * time.Hour)
  54. // 判断当前时间是否在 pzHour-4h 到 pzHour+4h 之间
  55. if nowTime.After(optimumMatingStartTime) && nowTime.Before(optimumMatingEndTime) {
  56. optimumMating["middle"] += 1
  57. }
  58. if nowTime.After(optimumMatingEndTime) {
  59. optimumMating["behind"] += 1
  60. }
  61. if nowTime.Before(optimumMatingStartTime) {
  62. optimumMating["front"] += 1
  63. }
  64. }
  65. abortionCount := int64(0)
  66. pref, err = s.AbortionWarningQuery(ctx, userModel.AppPasture.Id)
  67. if err != nil {
  68. return nil, xerr.Customf("系统错误!")
  69. }
  70. if err = pref.Group("cow_id").Count(&abortionCount).Error; err != nil {
  71. return nil, xerr.WithStack(err)
  72. }
  73. healthWarningNumber := int64(0)
  74. if err = s.DB.Model(new(model.NeckRingHealth)).
  75. Where("pasture_id = ?", userModel.AppPasture.Id).
  76. Group("cow_id").
  77. Count(&healthWarningNumber).Error; err != nil {
  78. zaplog.Error("NeckRingWarning", zap.Any("estrusWarningNumber", err))
  79. }
  80. return &pasturePb.IndexNeckRingResponse{
  81. Code: http.StatusOK,
  82. Msg: "ok",
  83. Data: &pasturePb.NeckRingData{
  84. EstrusWarningNumber: int32(countEstrusWarning),
  85. HealthWarningNumber: int32(healthWarningNumber),
  86. AbortionWarningNumber: int32(abortionCount),
  87. StressWarningNumber: 0,
  88. EstrusWarningLevelItems: estrusWarningLevelItems,
  89. OptimumMating: optimumMating,
  90. },
  91. }, nil
  92. }
  93. func (s *StoreEntry) FocusIndicatorsList(ctx context.Context, dimension string) (*pasturePb.IndexFocusIndicatorsResponse, error) {
  94. userModel, err := s.GetUserModel(ctx)
  95. if err != nil {
  96. return nil, xerr.WithStack(err)
  97. }
  98. userFocusIndicators := userModel.SystemUser.IndicatorsKinds
  99. if len(userFocusIndicators) <= 0 {
  100. userFocusIndicators = model.DefaultFocusIndicators
  101. }
  102. userFocusIndicatorsList := strings.Split(userFocusIndicators, ",")
  103. indicatorsDataList := make([]*model.IndicatorsData, 0)
  104. pref := s.DB.Model(new(model.IndicatorsData)).
  105. Where("pasture_id = ?", userModel.AppPasture.Id).
  106. Where("kind in (?)", userFocusIndicatorsList)
  107. /*if dimension == "Year" {
  108. pref.Where("date = ?", time.Now().Local().Format(model.LayoutMonth))
  109. }*/
  110. nowTime := time.Now().Local()
  111. if dimension == "Month" {
  112. pref.Where("date = ?", nowTime.Format(model.LayoutMonth))
  113. }
  114. if err = pref.Find(&indicatorsDataList).Error; err != nil {
  115. zaplog.Error("FocusIndicators", zap.Any("err", err))
  116. }
  117. indicatorsDetailsMap, _, err := s.GetIndicatorsDetailsMap(ctx)
  118. if err != nil {
  119. return nil, xerr.WithStack(err)
  120. }
  121. focusIndicatorsList := make([]*pasturePb.FocusIndicators, 0)
  122. for _, v := range indicatorsDataList {
  123. indicatorsDetails, ok := indicatorsDetailsMap[v.Kind]
  124. if !ok {
  125. continue
  126. }
  127. onYear, onMonth := "", ""
  128. isUp := pasturePb.IsShow_Ok
  129. if dimension == "Year" {
  130. return nil, xerr.Custom("暂不支持该维度")
  131. }
  132. if dimension == "Month" {
  133. lastMonth := nowTime.AddDate(0, -1, 0).Format(model.LayoutMonth)
  134. oldIndicators, _ := s.GetIndicatorsDataByDate(userModel.AppPasture.Id, v.Kind, lastMonth)
  135. if oldIndicators != nil {
  136. if oldIndicators.Value != "" && oldIndicators.Value != "0" {
  137. oldValue, _ := strconv.ParseFloat(oldIndicators.Value, 64)
  138. currValue, _ := strconv.ParseFloat(v.Value, 64)
  139. onMonthValue := (oldValue - currValue) / oldValue * 100
  140. omv := util.RoundToTwoDecimals(onMonthValue)
  141. if omv < 0 {
  142. isUp = pasturePb.IsShow_No
  143. }
  144. onMonth = strconv.FormatFloat(omv, 'f', 2, 64) + "%"
  145. }
  146. }
  147. }
  148. focusIndicatorsList = append(focusIndicatorsList, &pasturePb.FocusIndicators{
  149. Kind: indicatorsDetails.Kind,
  150. Name: indicatorsDetails.Name,
  151. Value: v.Value,
  152. Describe: indicatorsDetails.Zh,
  153. UnitName: indicatorsDetails.Unit,
  154. OnMonth: onMonth,
  155. OnYear: onYear,
  156. IsUp: isUp,
  157. })
  158. }
  159. indicatorsDetailsList, _ := s.FindIndicatorsDetailsList(ctx)
  160. return &pasturePb.IndexFocusIndicatorsResponse{
  161. Code: http.StatusOK,
  162. Msg: "ok",
  163. Data: &pasturePb.FocusData{
  164. FocusIndicators: focusIndicatorsList,
  165. IndicatorsSet: model.IndicatorsDetailsSlice(indicatorsDetailsList).ToPB(userFocusIndicatorsList),
  166. },
  167. }, err
  168. }
  169. func (s *StoreEntry) FocusIndicatorsSet(ctx context.Context, req *pasturePb.IndexFocusIndicatorsSetRequest) error {
  170. userModel, err := s.GetUserModel(ctx)
  171. if err != nil {
  172. return xerr.WithStack(err)
  173. }
  174. if len(req.IndicatorsKind) <= 0 {
  175. return nil
  176. }
  177. userFocusIndicators := strings.Join(req.IndicatorsKind, ",")
  178. if err = s.DB.Model(new(model.SystemUser)).
  179. Where("id = ?", userModel.SystemUser.Id).
  180. Update("indicators_kinds", userFocusIndicators).Error; err != nil {
  181. return xerr.WithStack(err)
  182. }
  183. return nil
  184. }
  185. func (s *StoreEntry) DataWarningSet(ctx context.Context, req *pasturePb.IndexDataWarningSetRequest) error {
  186. userModel, err := s.GetUserModel(ctx)
  187. if err != nil {
  188. return xerr.WithStack(err)
  189. }
  190. pastureId := userModel.AppPasture.Id
  191. if len(req.WarningDataSet) <= 0 {
  192. return xerr.Custom("请选择预警数据")
  193. }
  194. defaultDataWarning, _ := s.FindDataWarning(ctx, pastureId, model.DefaultUserId)
  195. if len(defaultDataWarning) <= 0 {
  196. return xerr.Custom("默认预警数据不存在,请联系管理员!")
  197. }
  198. userDataWarningList, err := s.FindDataWarning(ctx, pastureId, userModel.SystemUser.Id)
  199. if err != nil {
  200. return xerr.WithStack(err)
  201. }
  202. if len(userDataWarningList) <= 0 { // 新增
  203. return s.addUserDataWarning(ctx, pastureId, userModel.SystemUser.Id, defaultDataWarning, req.WarningDataSet)
  204. }
  205. return s.updateUserDataWarning(ctx, pastureId, userModel.SystemUser.Id, userDataWarningList, req.WarningDataSet)
  206. }
  207. func (s *StoreEntry) DataWarningList(ctx context.Context) (*pasturePb.IndexDataWarningResponse, error) {
  208. userModel, err := s.GetUserModel(ctx)
  209. if err != nil {
  210. return nil, xerr.WithStack(err)
  211. }
  212. pastureId := userModel.AppPasture.Id
  213. defaultDataWarning, _ := s.FindDataWarning(ctx, pastureId, model.DefaultUserId)
  214. if len(defaultDataWarning) <= 0 {
  215. return nil, xerr.Custom("默认预警数据有误,请联系管理员!")
  216. }
  217. var isExist bool // 判断是否存在自己的设置的数据
  218. userDataWarning, _ := s.FindDataWarning(ctx, pastureId, userModel.SystemUser.Id)
  219. if len(userDataWarning) == 0 {
  220. // 如果用户没有配置自己的预警数据,则使用默认数据
  221. isExist = true
  222. userDataWarning = defaultDataWarning
  223. }
  224. newTime := time.Now().Local().Unix()
  225. needUpdateWarningIds := make([]int64, 0)
  226. for _, warningData := range userDataWarning {
  227. // 如果预警数据更新时间大于预警条件更新时间,并且更新时间距离当前时间小于2小时,则跳过
  228. if warningData.DataUpdateAt > warningData.ConditionUpdateAt && newTime-warningData.DataUpdateAt < int64(2*time.Hour) {
  229. continue
  230. }
  231. needUpdateWarningIds = append(needUpdateWarningIds, warningData.Id)
  232. }
  233. // 需要重新计算更新的warningId
  234. if len(needUpdateWarningIds) > 0 {
  235. s.UpdateWarningData(ctx, pastureId, needUpdateWarningIds)
  236. }
  237. userDataWarningItems := make([]*model.DataWarningItems, 0)
  238. // 计算过后重新获取数据
  239. if isExist {
  240. userDataWarning, _ = s.FindDataWarning(ctx, pastureId, model.DefaultUserId)
  241. userDataWarningItems, _ = s.FindDataWarningItems(ctx, pastureId, model.DefaultUserId)
  242. } else {
  243. userDataWarning, _ = s.FindDataWarning(ctx, pastureId, userModel.SystemUser.Id)
  244. userDataWarningItems, _ = s.FindDataWarningItems(ctx, pastureId, userModel.SystemUser.Id)
  245. }
  246. return &pasturePb.IndexDataWarningResponse{
  247. Code: http.StatusOK,
  248. Msg: "ok",
  249. Data: &pasturePb.DataWarning{
  250. DataSet: model.DataWarningItemsSlice(userDataWarningItems).ToPB(userDataWarning),
  251. DataShow: model.DataWarningSlice(userDataWarning).ToPB(),
  252. },
  253. }, nil
  254. }
  255. func (s *StoreEntry) DataWarningPop(ctx context.Context, req *pasturePb.WarningDataListRequest, pagination *pasturePb.PaginationModel) (*model.WarningDataPopResponse, error) {
  256. userModel, err := s.GetUserModel(ctx)
  257. if err != nil {
  258. return nil, xerr.WithStack(err)
  259. }
  260. if req.Kind <= pasturePb.DataWarningType_Invalid {
  261. return nil, xerr.Custom("请选择预警数据")
  262. }
  263. pastureId := userModel.AppPasture.Id
  264. dataWaringItem := &model.DataWarning{}
  265. if err = s.DB.Model(new(model.DataWarning)).
  266. Where("pasture_id = ?", pastureId).
  267. Where("user_id = ?", userModel.SystemUser.Id).
  268. Where("kind = ?", req.Kind).
  269. First(dataWaringItem).Error; err != nil {
  270. if errors.Is(err, gorm.ErrRecordNotFound) {
  271. if err = s.DB.Model(new(model.DataWarning)).
  272. Where("pasture_id = ?", pastureId).
  273. Where("user_id = ?", model.DefaultUserId).
  274. Where("kind = ?", req.Kind).
  275. First(dataWaringItem).Error; err != nil {
  276. return nil, xerr.WithStack(err)
  277. }
  278. } else {
  279. return nil, xerr.Custom("预警数据不存在,请联系管理员!")
  280. }
  281. }
  282. headers, headerSort, err := dataWaringItem.GetWarningColumn()
  283. if err != nil {
  284. return nil, xerr.WithStack(err)
  285. }
  286. resp := &model.WarningDataPopResponse{
  287. Code: http.StatusOK,
  288. Msg: "ok",
  289. Data: &model.WarningPop{
  290. DataList: make([]interface{}, 0),
  291. Title: dataWaringItem.Name,
  292. Kind: dataWaringItem.Kind,
  293. HeaderSort: headerSort,
  294. Headers: headers,
  295. Page: pagination.Page,
  296. PageSize: pagination.PageSize,
  297. Total: 0,
  298. },
  299. }
  300. query, params, err := s.BuildQuery(dataWaringItem.Id)
  301. if err != nil {
  302. zaplog.Error("UpdateWarningData", zap.Any("BuildQuery", err), zap.Any("warningId", dataWaringItem.Id))
  303. return resp, nil
  304. }
  305. if len(query) == 0 || len(params) == 0 {
  306. return resp, nil
  307. }
  308. var count int64
  309. cowList := make([]*model.Cow, 0)
  310. if err = s.DB.Model(new(model.Cow)).
  311. Where("pasture_id = ?", pastureId).
  312. Where(query, params...).
  313. Count(&count).
  314. Limit(int(pagination.PageSize)).
  315. Offset(int(pagination.PageOffset)).
  316. Find(&cowList).
  317. Error; err != nil {
  318. zaplog.Error("UpdateWarningData", zap.Any("err", err), zap.Any("query", query), zap.Any("params", params))
  319. }
  320. cowTypeMap := s.CowTypeMap()
  321. breedStatusMap := s.CowBreedStatusMap()
  322. cowKindMap := s.CowKindMap()
  323. cowSourceMap := s.CowSourceMap()
  324. admissionStatusMap := s.AdmissionStatusMap()
  325. healthStatusMap := s.HealthStatusMap()
  326. purposeMap := s.PurposeMap()
  327. resp.Data.Total = int32(count)
  328. systemBasic, err := s.GetSystemBasicByName(ctx, userModel.AppPasture.Id, model.PregnancyAge)
  329. if err != nil {
  330. return nil, xerr.Custom("请在基础参数配置妊娠天数")
  331. }
  332. resp.Data.DataList = model.CowSlice(cowList).ToPB(
  333. cowTypeMap, breedStatusMap, cowKindMap,
  334. cowSourceMap, admissionStatusMap, healthStatusMap,
  335. purposeMap, systemBasic.MinValue,
  336. )
  337. return resp, nil
  338. }
  339. // 新增用户预警数据
  340. func (s *StoreEntry) addUserDataWarning(ctx context.Context, pastureId, userId int64, defaultDataWarning []*model.DataWarning, warningDataSet []*pasturePb.WarningDataSet) error {
  341. // 将默认预警数据按 Kind 映射
  342. defaultDataWarningMap := make(map[pasturePb.DataWarningType_Kind]*model.DataWarning)
  343. for _, v := range defaultDataWarning {
  344. defaultDataWarningMap[v.Kind] = v
  345. }
  346. // 在事务中执行新增操作
  347. return s.DB.Transaction(func(tx *gorm.DB) error {
  348. addedKinds := make(map[pasturePb.DataWarningType_Kind]bool) // 记录已添加的 Kind
  349. for _, set := range warningDataSet {
  350. dataWarning := model.NewDataWarning(pastureId, userId, set.Kind, pasturePb.IsShow_Ok, defaultDataWarningMap[set.Kind])
  351. // 如果该 Kind 已添加,跳过
  352. if !addedKinds[set.Kind] {
  353. // 创建新的预警数据
  354. if err := tx.Model(new(model.DataWarning)).
  355. Create(dataWarning).Error; err != nil {
  356. return xerr.WithStack(err)
  357. }
  358. } else {
  359. oldDataWarning := &model.DataWarning{}
  360. if err := tx.Model(new(model.DataWarning)).
  361. Where("user_id = ?", userId).
  362. Where("kind = ?", set.Kind).
  363. First(oldDataWarning).Error; err != nil {
  364. return xerr.WithStack(err)
  365. }
  366. dataWarning.Id = oldDataWarning.Id
  367. }
  368. // 创建预警项数据
  369. if err := tx.Model(new(model.DataWarningItems)).
  370. Create(model.NewDataWarningItems(pastureId, userId, dataWarning, set)).Error; err != nil {
  371. return xerr.WithStack(err)
  372. }
  373. addedKinds[set.Kind] = true
  374. }
  375. return nil
  376. })
  377. }
  378. // 更新用户预警数据
  379. func (s *StoreEntry) updateUserDataWarning(ctx context.Context, pastureId, userId int64, userDataWarningList []*model.DataWarning, warningDataSet []*pasturePb.WarningDataSet) error {
  380. // 将请求数据按 WarningId 和 Id 映射
  381. warningIsShowMap := make(map[int32]*pasturePb.WarningDataSet)
  382. warningItemDataMap := make(map[int32]*pasturePb.WarningDataSet)
  383. for _, set := range warningDataSet {
  384. warningIsShowMap[set.WarningId] = set
  385. warningItemDataMap[set.Id] = set
  386. }
  387. // 获取用户预警项数据
  388. userDataWarningItems, err := s.FindDataWarningItems(ctx, pastureId, userId)
  389. if err != nil {
  390. return xerr.WithStack(err)
  391. }
  392. if len(userDataWarningItems) == 0 {
  393. return xerr.Custom("预警数据有误,请联系管理员!")
  394. }
  395. // 在事务中执行更新操作
  396. return s.DB.Transaction(func(tx *gorm.DB) error {
  397. // 更新预警数据的 IsShow 字段
  398. for _, warning := range userDataWarningList {
  399. if data, ok := warningIsShowMap[int32(warning.Id)]; ok {
  400. if strings.ContainsAny(warning.Name, "0123456789") {
  401. re := regexp.MustCompile(`\d+`)
  402. warning.Name = re.ReplaceAllString(warning.Name, data.Value)
  403. warning.Description = re.ReplaceAllString(warning.Description, data.Value)
  404. }
  405. if err = tx.Model(&model.DataWarning{}).
  406. Where("id = ?", warning.Id).
  407. Updates(map[string]interface{}{
  408. "is_show": data.IsShow,
  409. "name": warning.Name,
  410. "description": warning.Description,
  411. }).Error; err != nil {
  412. return xerr.WithStack(err)
  413. }
  414. }
  415. }
  416. // 更新预警项数据的 IsShow 和 Value 字段
  417. for _, item := range userDataWarningItems {
  418. if set, ok := warningItemDataMap[int32(item.Id)]; ok {
  419. value := set.Value
  420. if set.FieldName == model.FieldName {
  421. v1, _ := strconv.ParseInt(set.Value, 10, 64)
  422. value = fmt.Sprintf("%d", v1*30)
  423. }
  424. if err = tx.Model(&model.DataWarningItems{}).
  425. Where("id = ?", item.Id).
  426. Updates(map[string]interface{}{
  427. "is_show": set.IsShow,
  428. "value": value,
  429. }).Error; err != nil {
  430. return xerr.WithStack(err)
  431. }
  432. }
  433. }
  434. return nil
  435. })
  436. }
  437. func (s *StoreEntry) FindDataWarning(ctx context.Context, pastureId, userId int64) ([]*model.DataWarning, error) {
  438. dataWarningList := make([]*model.DataWarning, 0)
  439. if err := s.DB.Model(new(model.DataWarning)).
  440. Where("user_id = ?", userId).
  441. Where("pasture_id = ?", pastureId).
  442. Find(&dataWarningList).Error; err != nil {
  443. return nil, xerr.WithStack(err)
  444. }
  445. return dataWarningList, nil
  446. }
  447. func (s *StoreEntry) FindDataWarningItems(ctx context.Context, pastureId, userId int64) ([]*model.DataWarningItems, error) {
  448. dataWarningItemsList := make([]*model.DataWarningItems, 0)
  449. if err := s.DB.Model(new(model.DataWarningItems)).
  450. Where("pasture_id = ?", pastureId).
  451. Where("user_id = ?", userId).
  452. Find(&dataWarningItemsList).Error; err != nil {
  453. return nil, xerr.WithStack(err)
  454. }
  455. return dataWarningItemsList, nil
  456. }
  457. func (s *StoreEntry) FindDataWarningMap(ctx context.Context, pastureId, userId int64) (map[int64]*model.DataWarning, error) {
  458. dataWarning, err := s.FindDataWarning(ctx, pastureId, userId)
  459. if err != nil {
  460. return nil, xerr.Custom("默认预警数据有误,请联系管理员!")
  461. }
  462. dataWarningMap := make(map[int64]*model.DataWarning)
  463. for _, v := range dataWarning {
  464. dataWarningMap[v.Id] = v
  465. }
  466. return dataWarningMap, nil
  467. }
  468. func (s *StoreEntry) FindDataWarningItemsMap(ctx context.Context, userId int64) (map[int64]*model.DataWarningItems, error) {
  469. dataWarningItemsList := make([]*model.DataWarningItems, 0)
  470. if err := s.DB.Model(new(model.DataWarningItems)).
  471. Where("user_id = ?", userId).
  472. Find(&dataWarningItemsList).Error; err != nil {
  473. return nil, xerr.WithStack(err)
  474. }
  475. dataWarningItemsMap := make(map[int64]*model.DataWarningItems)
  476. for _, v := range dataWarningItemsList {
  477. dataWarningItemsMap[v.Id] = v
  478. }
  479. return dataWarningItemsMap, nil
  480. }
  481. // UpdateWarningData 更新计算数据
  482. func (s *StoreEntry) UpdateWarningData(ctx context.Context, pastureId int64, needUpdateWarningIds []int64) {
  483. if len(needUpdateWarningIds) <= 0 {
  484. return
  485. }
  486. for _, warningId := range needUpdateWarningIds {
  487. query, params, err := s.BuildQuery(warningId)
  488. if err != nil {
  489. zaplog.Error("UpdateWarningData", zap.Any("BuildQuery", err), zap.Any("warningId", warningId))
  490. }
  491. if len(query) == 0 || len(params) == 0 {
  492. continue
  493. }
  494. var count int64
  495. if err = s.DB.Model(new(model.Cow)).
  496. Where("pasture_id = ?", pastureId).
  497. Where(query, params...).
  498. Count(&count).Error; err != nil {
  499. zaplog.Error("UpdateWarningData", zap.Any("err", err), zap.Any("query", query), zap.Any("params", params))
  500. }
  501. if err = s.DB.Model(new(model.DataWarning)).
  502. Where("id = ?", warningId).
  503. Updates(map[string]interface{}{
  504. "data_value": count,
  505. "data_update_at": time.Now().Local().Unix(),
  506. }).Error; err != nil {
  507. zaplog.Error("UpdateWarningData", zap.Any("update", err))
  508. }
  509. }
  510. }