From b64e1b681921a8995f0d9e871d944a3cd752b3a3 Mon Sep 17 00:00:00 2001 From: liuchengqian Date: Sun, 12 Mar 2023 15:03:38 +0800 Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0=E8=84=9A=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../DispatchFirePointController.java | 99 +++++++------------ .../com/xkrs/dao/FirePointOrdinaryDao.java | 19 ++++ 2 files changed, 57 insertions(+), 61 deletions(-) diff --git a/src/main/java/com/xkrs/controller/DispatchFirePointController.java b/src/main/java/com/xkrs/controller/DispatchFirePointController.java index 6d5af0a..f8de342 100644 --- a/src/main/java/com/xkrs/controller/DispatchFirePointController.java +++ b/src/main/java/com/xkrs/controller/DispatchFirePointController.java @@ -6,14 +6,16 @@ import com.xkrs.dao.FirePointPreciseDao; import com.xkrs.dao.StreetDao; import com.xkrs.dao.SysUserDao; import com.xkrs.helper.FirePointSubscribeManager; -import com.xkrs.model.entity.FirePointOrdinaryEntity; +import com.xkrs.model.bean.VipTimeRangeBean; +import com.xkrs.model.entity.SysUserEntity; import com.xkrs.model.qo.AllFirePointQo; import com.xkrs.service.DispatchFirePointService; import com.xkrs.service.impl.FirePointServiceImpl; +import com.xkrs.utilsnew.JsonUtils; +import com.xkrs.utilsold.DateTimeUtil; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.i18n.LocaleContextHolder; -import org.springframework.data.domain.Sort; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; @@ -23,7 +25,6 @@ import javax.annotation.Resource; import java.util.ArrayList; import java.util.List; import java.util.Locale; -import java.util.Map; import static com.xkrs.common.encapsulation.OutputEncapsulation.outputEncapsulationObject; @@ -48,66 +49,42 @@ public class DispatchFirePointController { @GetMapping("/debug") public String debug() { -// List sysUserEntityList = sysUserDao.findAll(); -// for (SysUserEntity sysUserEntity : sysUserEntityList) { -// String addTime = sysUserEntity.getAddTime(); -// String vipTimeRangeJson = sysUserEntity.getVipTimeRangeJson(); -// if (!DateTimeUtil.isValidDateTime(addTime)) { -// return sysUserEntity.getUserName(); -// } -// if (!DateTimeUtil.isValidDateTime(vipTimeRangeJson)) { -// return sysUserEntity.getUserName(); -// } -// VipTimeRangeBean.VipTimeRangeItemBean vipTimeRangeItemBean = new VipTimeRangeBean.VipTimeRangeItemBean(); -// vipTimeRangeItemBean.setStartTime(addTime); -// vipTimeRangeItemBean.setEndTime(vipTimeRangeJson); -// List list = new ArrayList<>(); -// list.add(vipTimeRangeItemBean); -// VipTimeRangeBean vipTimeRangeBean = new VipTimeRangeBean(); -// vipTimeRangeBean.setList(list); -// String serialize = JsonUtils.serialize(vipTimeRangeBean); -// System.out.println("serialize = " + serialize); -// sysUserEntity.setVipTimeRangeJson(serialize); -// sysUserDao.save(sysUserEntity); + System.out.println("开始更新用户VIP时间范围"); + + List sysUserEntityList = sysUserDao.findAll(); + for (SysUserEntity sysUserEntity : sysUserEntityList) { + String addTime = sysUserEntity.getAddTime(); + String vipTimeRangeJson = sysUserEntity.getVipTimeRangeJson(); + if (!DateTimeUtil.isValidDateTime(addTime)) { + return sysUserEntity.getUserName(); + } + if (!DateTimeUtil.isValidDateTime(vipTimeRangeJson)) { + return sysUserEntity.getUserName(); + } + VipTimeRangeBean.VipTimeRangeItemBean vipTimeRangeItemBean = new VipTimeRangeBean.VipTimeRangeItemBean(); + vipTimeRangeItemBean.setStartTime(addTime); + vipTimeRangeItemBean.setEndTime(vipTimeRangeJson); + List list = new ArrayList<>(); + list.add(vipTimeRangeItemBean); + VipTimeRangeBean vipTimeRangeBean = new VipTimeRangeBean(); + vipTimeRangeBean.setList(list); + String serialize = JsonUtils.serialize(vipTimeRangeBean); + System.out.println("serialize = " + serialize); + sysUserEntity.setVipTimeRangeJson(serialize); + sysUserDao.save(sysUserEntity); + } + + System.out.println("开始更新省编码市编码"); + firePointOrdinaryDao.updateProCityCode(); + System.out.println("开始更新省名市名"); + firePointOrdinaryDao.updateProCityName(); + +// for (int i = 0; i < 30; i++) { +// firePointOrdinaryDao.updateProCityCodeById((long) i); +// firePointOrdinaryDao.updateProCityNameById((long) i); // } - List> maps = streetDao.selectProCityPair(); - List firePointOrdinaryEntityList = firePointOrdinaryDao.findAll(Sort.by(Sort.Direction.DESC, "satelliteTime")); - int size = firePointOrdinaryEntityList.size(); - List errorList = new ArrayList<>(); - for (int i = 0; i < size; i++) { - FirePointOrdinaryEntity firePointOrdinaryEntity = firePointOrdinaryEntityList.get(i); - String countyCode = firePointOrdinaryEntity.getCountyCode(); - String proCode = countyCode.substring(0, 2) + "0000"; - firePointOrdinaryEntity.setProCode(proCode); - firePointOrdinaryEntity.setProName(obtainProName(maps, proCode)); - String cityCode = countyCode.substring(0, 4) + "00"; - firePointOrdinaryEntity.setCityCode(cityCode); - firePointOrdinaryEntity.setCityName(obtainCityName(maps, cityCode)); - firePointOrdinaryDao.save(firePointOrdinaryEntity); - if (i % 100 == 0) { - System.out.println(i + "/" + size); - } - } - return outputEncapsulationObject(PromptMessageEnum.SUCCESS, errorList, locale); - } - - private String obtainProName(List> maps, String proCode) { - for (Map map : maps) { - if (map.get("pro_code").equals(proCode)) { - return map.get("pro_name"); - } - } - return null; - } - - private String obtainCityName(List> maps, String cityCode) { - for (Map map : maps) { - if (map.get("city_code").equals(cityCode)) { - return map.get("city_name"); - } - } - return null; + return outputEncapsulationObject(PromptMessageEnum.SUCCESS, "OKKKK", locale); } @GetMapping("/autoSync") diff --git a/src/main/java/com/xkrs/dao/FirePointOrdinaryDao.java b/src/main/java/com/xkrs/dao/FirePointOrdinaryDao.java index 8b449d4..be1248b 100644 --- a/src/main/java/com/xkrs/dao/FirePointOrdinaryDao.java +++ b/src/main/java/com/xkrs/dao/FirePointOrdinaryDao.java @@ -3,8 +3,27 @@ package com.xkrs.dao; import com.xkrs.model.entity.FirePointOrdinaryEntity; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.JpaSpecificationExecutor; +import org.springframework.data.jpa.repository.Modifying; +import org.springframework.data.jpa.repository.Query; import org.springframework.stereotype.Component; @Component public interface FirePointOrdinaryDao extends JpaRepository, JpaSpecificationExecutor { + + @Query(value = "UPDATE fire_point_ordinary SET pro_code = concat(left(county_code, 2), '0000'), city_code = concat(left(county_code, 4), '00')", nativeQuery = true) + @Modifying(clearAutomatically = true) + void updateProCityCode(); + + @Query(value = "UPDATE fire_point_ordinary AS f SET pro_name = (SELECT s.pro_name AS proname FROM street AS s WHERE s.pro_code = f.pro_code LIMIT 1), city_name = (SELECT s.city_name AS cityname FROM street AS s WHERE s.city_code = f.city_code LIMIT 1)", nativeQuery = true) + @Modifying(clearAutomatically = true) + void updateProCityName(); + + @Query(value = "UPDATE fire_point_ordinary SET pro_code = concat(left(county_code, 2), '0000'), city_code = concat(left(county_code, 4), '00') WHERE id = ?1", nativeQuery = true) + @Modifying(clearAutomatically = true) + void updateProCityCodeById(Long id); + + @Query(value = "UPDATE fire_point_ordinary AS f SET pro_name = (SELECT s.pro_name AS proname FROM street AS s WHERE s.pro_code = f.pro_code LIMIT 1), city_name = (SELECT s.city_name AS cityname FROM street AS s WHERE s.city_code = f.city_code LIMIT 1) WHERE id = ?1", nativeQuery = true) + @Modifying(clearAutomatically = true) + void updateProCityNameById(Long id); + }