forked from angelo/java-retail-app
## 行政区划新增(百度api)
This commit is contained in:
parent
bb0a714805
commit
b261ff7a61
|
@ -0,0 +1,17 @@
|
||||||
|
package com.hzs.system.base;
|
||||||
|
|
||||||
|
import cn.hutool.json.JSONObject;
|
||||||
|
import com.hzs.common.core.domain.R;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* 服务类
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @author hzs
|
||||||
|
* @since 2025-10-10
|
||||||
|
*/
|
||||||
|
public interface IBdAreaNewServiceApi {
|
||||||
|
|
||||||
|
R<?> upAreaDate(JSONObject result);
|
||||||
|
}
|
|
@ -0,0 +1,16 @@
|
||||||
|
package com.hzs.system.base.mapper;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.hzs.common.domain.system.base.BdAreaNew;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* Mapper 接口
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @author hzs
|
||||||
|
* @since 2025-10-10
|
||||||
|
*/
|
||||||
|
public interface BdAreaNewMapper extends BaseMapper<BdAreaNew> {
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,139 @@
|
||||||
|
package com.hzs.system.base.provider;
|
||||||
|
|
||||||
|
import cn.hutool.json.JSONArray;
|
||||||
|
import cn.hutool.json.JSONObject;
|
||||||
|
import com.hzs.common.core.constant.CountryConstants;
|
||||||
|
import com.hzs.common.core.constant.MagicNumberConstants;
|
||||||
|
import com.hzs.common.core.domain.R;
|
||||||
|
import com.hzs.common.domain.system.base.BdAreaNew;
|
||||||
|
import com.hzs.system.base.IBdAreaNewServiceApi;
|
||||||
|
import com.hzs.system.base.service.IBdAreaNewService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.apache.dubbo.config.annotation.DubboService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.jdbc.core.JdbcTemplate;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* 服务实现类
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @author hzs
|
||||||
|
* @since 2025-10-10
|
||||||
|
*/
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@DubboService
|
||||||
|
public class BdAreaNewServiceProvider implements IBdAreaNewServiceApi {
|
||||||
|
@Autowired
|
||||||
|
private IBdAreaNewService iBdAreaNewService;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private JdbcTemplate jdbcTemplate;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public R<?> upAreaDate(JSONObject result) {
|
||||||
|
|
||||||
|
Set<String> allCodesFromApi = new HashSet<>();
|
||||||
|
// 最外层,全国,直接过滤
|
||||||
|
JSONArray country = result.getJSONArray("districts");
|
||||||
|
// 省
|
||||||
|
JSONObject provinces = country.getJSONObject(0);
|
||||||
|
// 省列表
|
||||||
|
JSONArray provincesArray = provinces.getJSONArray("districts");
|
||||||
|
// 查询所有数据
|
||||||
|
List<BdAreaNew> allDbAreas = iBdAreaNewService.list();
|
||||||
|
Map<String, BdAreaNew> dbMap = allDbAreas.stream()
|
||||||
|
.collect(Collectors.toMap(BdAreaNew::getCode, a -> a));
|
||||||
|
|
||||||
|
for (int i = 0; i < provincesArray.size(); i++) {
|
||||||
|
// 迭代处理数据
|
||||||
|
parseDistrict(provincesArray.getJSONObject(i), 0L, allCodesFromApi,dbMap);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 对数据库中未出现的地区进行逻辑删除标记
|
||||||
|
for (BdAreaNew bdAreaNew : allDbAreas) {
|
||||||
|
if (!allCodesFromApi.contains(bdAreaNew.getCode()) && bdAreaNew.getDelFlag() == 0) {
|
||||||
|
bdAreaNew.setSyncStatus("DELETED");
|
||||||
|
iBdAreaNewService.removeById(bdAreaNew);
|
||||||
|
iBdAreaNewService.updateById(bdAreaNew);
|
||||||
|
log.info("逻辑删除地区:{}", bdAreaNew.getName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return R.ok();
|
||||||
|
}
|
||||||
|
private void parseDistrict(JSONObject district, Long parentId, Set<String> allCodesFromApi,
|
||||||
|
Map<String, BdAreaNew> dbMap) {
|
||||||
|
if ("4".equals(district.getStr("level")) || "990000".equals(district.getStr("code"))) {
|
||||||
|
// 第4级行政区划(街道)和990000这个地区不需要
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// 操作用户
|
||||||
|
Long userId = MagicNumberConstants.PK_ADMIN;
|
||||||
|
// 所属国家
|
||||||
|
Integer pkCountry = CountryConstants.CHINA_COUNTRY;
|
||||||
|
// 当前时间
|
||||||
|
Date nowDate = new Date();
|
||||||
|
String name = district.getStr("name");
|
||||||
|
String code = district.getStr("code");
|
||||||
|
allCodesFromApi.add(code);
|
||||||
|
|
||||||
|
BdAreaNew existing = dbMap.get(code);
|
||||||
|
|
||||||
|
if (existing == null) {
|
||||||
|
BdAreaNew area = new BdAreaNew();
|
||||||
|
Integer newId = getNextSeqId();
|
||||||
|
area.setPkId(newId);
|
||||||
|
area.setName(name);
|
||||||
|
area.setCode(code);
|
||||||
|
area.setParent(parentId == null ? 0L : parentId);
|
||||||
|
area.setEnableState(0);
|
||||||
|
area.setDelFlag(0);
|
||||||
|
area.setPkCountry(pkCountry);
|
||||||
|
area.setPkCreator(userId);
|
||||||
|
area.setCreationTime(nowDate);
|
||||||
|
area.setBindNum(1);
|
||||||
|
area.setSyncStatus("NEW");
|
||||||
|
|
||||||
|
iBdAreaNewService.save(area);
|
||||||
|
dbMap.put(code, area);
|
||||||
|
existing = area;
|
||||||
|
log.info("新增地区:{} code={} pkId={}", name, code, newId);
|
||||||
|
} else {
|
||||||
|
boolean updated = false;
|
||||||
|
if (!existing.getName().equals(name)) {
|
||||||
|
existing.setName(name);
|
||||||
|
updated = true;
|
||||||
|
}
|
||||||
|
if (!Objects.equals(existing.getParent(), parentId)) {
|
||||||
|
existing.setParent(parentId == null ? 0L : parentId);
|
||||||
|
updated = true;
|
||||||
|
existing.setSyncStatus("MOVED");
|
||||||
|
}
|
||||||
|
if (updated) {
|
||||||
|
existing.setModifiedTime(new Date());
|
||||||
|
iBdAreaNewService.updateById(existing);
|
||||||
|
log.info("更新地区:{} code={}", name, code);
|
||||||
|
} else {
|
||||||
|
existing.setSyncStatus("NORMAL");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Integer currentParentId = existing.getPkId();
|
||||||
|
JSONArray subList = district.getJSONArray("districts");
|
||||||
|
if (subList != null && !subList.isEmpty()) {
|
||||||
|
for (int i = 0; i < subList.size(); i++) {
|
||||||
|
parseDistrict(subList.getJSONObject(i), Long.valueOf(currentParentId), allCodesFromApi, dbMap);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private Integer getNextSeqId() {
|
||||||
|
return jdbcTemplate.queryForObject("SELECT BD_AREA_NEW_SEQ.NEXTVAL FROM dual", Integer.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,16 @@
|
||||||
|
package com.hzs.system.base.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.hzs.common.domain.system.base.BdAreaNew;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* 服务类
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @author hzs
|
||||||
|
* @since 2025-10-10
|
||||||
|
*/
|
||||||
|
public interface IBdAreaNewService extends IService<BdAreaNew> {
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,20 @@
|
||||||
|
package com.hzs.system.base.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.hzs.common.domain.system.base.BdAreaNew;
|
||||||
|
import com.hzs.system.base.mapper.BdAreaNewMapper;
|
||||||
|
import com.hzs.system.base.service.IBdAreaNewService;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
* 服务实现类
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @author hzs
|
||||||
|
* @since 2025-10-10
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class BdAreaNewServiceImpl extends ServiceImpl<BdAreaNewMapper, BdAreaNew> implements IBdAreaNewService {
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.hzs.system.base.mapper.BdAreaNewMapper">
|
||||||
|
|
||||||
|
</mapper>
|
|
@ -0,0 +1,56 @@
|
||||||
|
package com.hzs.common.domain.system.base;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.*;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import com.hzs.common.core.web.domain.BaseEntity;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>
|
||||||
|
*
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @author hzs
|
||||||
|
* @since 2025-10-10
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@TableName("BD_AREA_NEW")
|
||||||
|
@KeySequence("BD_AREA_NEW_SEQ")
|
||||||
|
public class BdAreaNew extends BaseEntity {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@TableField("PK_ID")
|
||||||
|
@TableId(type = IdType.INPUT)
|
||||||
|
private Integer pkId;
|
||||||
|
|
||||||
|
@TableField("NAME")
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
@TableField("CODE")
|
||||||
|
private String code;
|
||||||
|
|
||||||
|
@TableField("PARENT")
|
||||||
|
private Long parent;
|
||||||
|
|
||||||
|
@TableField("ENABLE_STATE")
|
||||||
|
private Integer enableState;
|
||||||
|
|
||||||
|
@TableField("BIND_NUM")
|
||||||
|
private Integer bindNum;
|
||||||
|
|
||||||
|
@TableField("LAST_SYNC_TIME")
|
||||||
|
private Date lastSyncTime;
|
||||||
|
|
||||||
|
@TableField("SYNC_STATUS")
|
||||||
|
private String syncStatus;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,52 @@
|
||||||
|
package com.hzs.third.job;
|
||||||
|
|
||||||
|
import cn.hutool.http.HttpUtil;
|
||||||
|
import cn.hutool.json.JSONObject;
|
||||||
|
import cn.hutool.json.JSONUtil;
|
||||||
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import com.hzs.common.core.domain.R;
|
||||||
|
import com.hzs.common.core.web.domain.AjaxResult;
|
||||||
|
import com.hzs.system.base.IBdAreaNewServiceApi;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.apache.dubbo.config.annotation.DubboReference;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("test-map")
|
||||||
|
public class MapJob {
|
||||||
|
|
||||||
|
private static final String AK = "k5I8XpHFt78QaQ8GHclQ3wEN57XlvErC";
|
||||||
|
|
||||||
|
private static final String API_URL = "https://api.map.baidu.com/api_region_search/v1/";
|
||||||
|
|
||||||
|
@DubboReference(timeout = 60000)
|
||||||
|
IBdAreaNewServiceApi iBdAreaNewServiceApi;
|
||||||
|
|
||||||
|
@RequestMapping("map-job")
|
||||||
|
public AjaxResult map() {
|
||||||
|
|
||||||
|
Map<String, Object> params = new HashMap<>();
|
||||||
|
params.put("ak", AK);
|
||||||
|
params.put("keyword", "全国");
|
||||||
|
params.put("extensions_code", "1");
|
||||||
|
params.put("sub_admin", "3");
|
||||||
|
|
||||||
|
String resultStr = HttpUtil.get(API_URL, params);
|
||||||
|
JSONObject result = JSONUtil.parseObj(resultStr);
|
||||||
|
if (result.getInt("status") != 0) {
|
||||||
|
log.error("百度地图API请求失败: {}", resultStr);
|
||||||
|
return AjaxResult.error();
|
||||||
|
}
|
||||||
|
// 对行政区划进行处理
|
||||||
|
R<?> R = iBdAreaNewServiceApi.upAreaDate(result);
|
||||||
|
if (R.isSuccess()) {
|
||||||
|
return AjaxResult.success();
|
||||||
|
}
|
||||||
|
return AjaxResult.error();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,34 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.hzs.com.hzs.common.domain.mapper.BdAreaNewMapper">
|
||||||
|
|
||||||
|
<!-- 通用查询映射结果 -->
|
||||||
|
<resultMap id="BaseResultMap" type="com.hzs.com.hzs.common.domain.entity.BdAreaNew">
|
||||||
|
<id column="PK_ID" property="pkId" />
|
||||||
|
<result column="CREATION_TIME" property="creationTime" />
|
||||||
|
<result column="MODIFIED_TIME" property="modifiedTime" />
|
||||||
|
<result column="DEL_FLAG" property="delFlag" />
|
||||||
|
<result column="PK_COUNTRY" property="pkCountry" />
|
||||||
|
<result column="PK_CREATOR" property="pkCreator" />
|
||||||
|
<result column="PK_MODIFIED" property="pkModified" />
|
||||||
|
<result column="NAME" property="name" />
|
||||||
|
<result column="CODE" property="code" />
|
||||||
|
<result column="PARENT" property="parent" />
|
||||||
|
<result column="ENABLE_STATE" property="enableState" />
|
||||||
|
<result column="BIND_NUM" property="bindNum" />
|
||||||
|
<result column="LAST_SYNC_TIME" property="lastSyncTime" />
|
||||||
|
<result column="SYNC_STATUS" property="syncStatus" />
|
||||||
|
</resultMap>
|
||||||
|
|
||||||
|
<!-- 通用查询结果列 -->
|
||||||
|
<sql id="Base_Column_List">
|
||||||
|
CREATION_TIME,
|
||||||
|
MODIFIED_TIME,
|
||||||
|
DEL_FLAG,
|
||||||
|
PK_COUNTRY,
|
||||||
|
PK_CREATOR,
|
||||||
|
PK_MODIFIED,
|
||||||
|
PK_ID, NAME, CODE, PARENT, ENABLE_STATE, BIND_NUM, LAST_SYNC_TIME, SYNC_STATUS
|
||||||
|
</sql>
|
||||||
|
|
||||||
|
</mapper>
|
Loading…
Reference in New Issue