From 189cb9a1b925fbdfde02c175b2d84f4fe00dbaa7 Mon Sep 17 00:00:00 2001
From: dougang <78125310@kidgrow.com>
Date: Thu, 03 Dec 2020 16:35:59 +0800
Subject: [PATCH] 增加医院信息同步redis

---
 kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/HospitalScreeningServiceImpl.java |   79 +++++++++++++++++++++++++++++++--------
 1 files changed, 63 insertions(+), 16 deletions(-)

diff --git a/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/HospitalScreeningServiceImpl.java b/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/HospitalScreeningServiceImpl.java
index ac8150b..313eaff 100644
--- a/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/HospitalScreeningServiceImpl.java
+++ b/kidgrow-business/kidgrow-opration-center/kidgrow-opration-center-biz/src/main/java/com/kidgrow/oprationcenter/service/impl/HospitalScreeningServiceImpl.java
@@ -9,6 +9,7 @@
 import com.kidgrow.oprationcenter.model.HospitalScreening;
 import com.kidgrow.oprationcenter.model.ScreeningHospitalDataExcel;
 import com.kidgrow.oprationcenter.service.IHospitalScreeningService;
+import com.kidgrow.redis.util.RedisUtils;
 import com.kidgrow.report.feign.ReportService;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.collections4.MapUtils;
@@ -20,11 +21,12 @@
 
 /**
  * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020<br>
+ *
+ * @version 1.0
  * @Description: 筛查医院信息表-未完待续<br>
  * @Project: 用户中心<br>
  * @CreateDate: Created in 2020-04-01 09:37:05 <br>
  * @Author: <a href="4345453@kidgrow.com">liuke</a>
- * @version 1.0
  */
 @Slf4j
 @Service
@@ -32,49 +34,56 @@
 
     @Autowired
     private ReportService reportService;
+    @Autowired
+    private RedisUtils redisUtils;
+
+    private static final String CUSOTMERHOSPITAL = "CUSOTMER_HOSPITAL";
 
     /**
      * 列表
+     *
      * @param params
      * @return
      */
     @Override
-    public PageResult<HospitalScreening> findList(Map<String, Object> params){
+    public PageResult<HospitalScreening> findList(Map<String, Object> params) {
         Page<HospitalScreening> page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit"));
-        List<HospitalScreening> list  =  baseMapper.findList(page, params);
+        List<HospitalScreening> list = baseMapper.findList(page, params);
         return PageResult.<HospitalScreening>builder().data(list).code(0).count(page.getTotal()).build();
     }
 
     /**
-   * 根据HospitalScreening对象当做查询条件进行查询
-   * @param hospitalScreening
-   * @return HospitalScreening
-   */
+     * 根据HospitalScreening对象当做查询条件进行查询
+     *
+     * @param hospitalScreening
+     * @return HospitalScreening
+     */
     @Override
-    public HospitalScreening findByObject(HospitalScreening hospitalScreening){
+    public HospitalScreening findByObject(HospitalScreening hospitalScreening) {
         return baseMapper.findByObject(hospitalScreening);
     }
 
     /**
      * 更新状态:推送装填,启停状态
+     *
      * @param params 包含:1、type:0推送,1启停
-     *                     2、ID :ID
-     *                     3、val:对用的值
+     *               2、ID :ID
+     *               3、val:对用的值
      * @return
      */
     @Override
     public ResultBody updateEnabled(Map<String, Object> params) {
-        int type =  MapUtils.getInteger(params,"type");
-        int val =  MapUtils.getInteger(params,"objVal");
-        long id =  MapUtils.getLong(params,"objId");
+        int type = MapUtils.getInteger(params, "type");
+        int val = MapUtils.getInteger(params, "objVal");
+        long id = MapUtils.getLong(params, "objId");
 
         HospitalScreening hospitalScreening = baseMapper.selectById(id);
 
-        if(hospitalScreening == null){
+        if (hospitalScreening == null) {
             return ResultBody.failed("医院数据不存在!");
         }
 
-        switch (type){
+        switch (type) {
             case 0:
                 hospitalScreening.setIsScreeningPush(val);
                 break;
@@ -87,11 +96,14 @@
 
         int count = baseMapper.updateById(hospitalScreening);
 
+        updateRedisById(hospitalScreening);
+
         return count > 0 ? ResultBody.ok().msg("更新成功") : ResultBody.failed("更新失败");
     }
 
     /**
      * 根据医院名称模糊查询医院数据列表
+     *
      * @param hospitalName
      * @return
      */
@@ -100,13 +112,48 @@
         return ResultBody.ok().data(baseMapper.findByName(hospitalName)).msg("查询成功");
     }
 
+    /**
+     * 医院数据导出
+     *
+     * @param param 参数
+     * @return
+     */
     @Override
     public List<ScreeningHospitalDataExcel> export(Map<String, Object> param) {
         List<ScreeningHospitalDataExcel> list = null;
         ResultBody resultBody = reportService.exportData(param);
-        if(resultBody.getCode() == 0 && resultBody.getData() != null){
+        if (resultBody.getCode() == 0 && resultBody.getData() != null) {
             list = JSONArray.parseArray(JSONArray.toJSONString(resultBody.getData()), ScreeningHospitalDataExcel.class);
         }
         return list;
     }
+
+    /**
+     * 初始化,将表中的数据放入redis中
+     */
+    @Override
+    public void tableToRedis() {
+        List<HospitalScreening> list = baseMapper.findAll();
+        if (list.size() > 0) {
+            if (redisUtils.hasKey(CUSOTMERHOSPITAL)) {
+                redisUtils.del(CUSOTMERHOSPITAL);
+            }
+
+            for (HospitalScreening hs : list) {
+                redisUtils.hset(CUSOTMERHOSPITAL, String.valueOf(hs.getId()), hs);
+            }
+        }
+    }
+
+    /**
+     * 更新redis
+     *
+     * @param hospitalScreening
+     */
+    @Override
+    public void updateRedisById(HospitalScreening hospitalScreening) {
+        if (redisUtils.hasKey(CUSOTMERHOSPITAL)) {
+            redisUtils.hset(CUSOTMERHOSPITAL, String.valueOf(hospitalScreening.getId()), hospitalScreening);
+        }
+    }
 }

--
Gitblit v1.8.0