3
0
Fork 0

## 行政区划新增(百度api)

This commit is contained in:
zhangheng 2025-10-10 18:04:31 +08:00
parent bb0a714805
commit b261ff7a61
9 changed files with 355 additions and 0 deletions

View File

@ -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);
}

View File

@ -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> {
}

View File

@ -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);
}
}

View File

@ -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> {
}

View File

@ -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 {
}

View File

@ -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>

View File

@ -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;
}

View File

@ -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();
}
}

View File

@ -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>