本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《
省市区联动在项目中算是比较常见的功能了,但是基础数据却非常多,网上很难找到比较全的数据,不过在github上有人利用爬虫抓取了国家统计局的数据,并生成了json文件,这样就可以利用java解析json文件并生成相应的sql文件,非常简单。(注意:数据不含港澳台,因为原json就没有。)
github地址
:
https://github.com/modood/Administrative-divisions-of-China
本文所使用到的json数据为上面链接所得
这里需要导入两个包:
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.54</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
解析的java代码如下:
private static void main() throws IOException {
// 我这里直接创建了一个springboot项目(习惯了)
ClassPathResource resource = new ClassPathResource("pcas-code.json");
// 需要生成到的位置,我直接放在了项目中
File regionFile = new File("/Users/XXXXXXXX/demo/src/main/resources/region.sql");
// 不存在则创建,存在则覆盖
if (regionFile.exists()) {
regionFile.delete();
regionFile.createNewFile();
} else {
regionFile.createNewFile();
System.out.println(regionFile.getPath());
// 写入文件即可
Writer writer = new FileWriter(regionFile);
File file = resource.getFile();
String jsonString = FileUtils.readFileToString(file);
JSONArray jsonArray = JSONArray.parseArray(jsonString);
for (int i = 0; i < jsonArray.size(); i++) {
JSONObject jsonObject = jsonArray.getJSONObject(i);
String code = jsonObject.getString("code");
String name = jsonObject.getString("name");
String sql = "insert into region(code, name, pid) values('"+code+"', '"+name+"', '0');";
// System.out.println(sql);
writer.write(sql);
writer.write("\r\n");
JSONArray children = jsonObject.getJSONArray("children");
if (children != null) {
for (int i1 = 0; i1 < children.size(); i1++) {
JSONObject jsonObject1 = children.getJSONObject(i1);
String code1 = jsonObject1.getString("code");
String name1 = jsonObject1.getString("name");
String sql1 = "insert into region(code, name, pid) values('"+code1+"', '"+name1+"', '"+code+"');";
// System.out.println(sql1);
writer.write(sql1);
writer.write("\r\n");
JSONArray children1 = jsonObject1.getJSONArray("children");
if (children1 != null) {
for (int i2 = 0; i2 < children1.size(); i2++) {
JSONObject jsonObject2 = children1.getJSONObject(i2);
String code2 = jsonObject2.getString("code");
String name2 = jsonObject2.getString("name");
String sql2 = "insert into region(code, name, pid) values('"+code2+"', '"+name2+"', '"+code1+"');";
// System.out.println(sql2);
writer.write(sql2);
writer.write("\r\n");
JSONArray children2 = jsonObject2.getJSONArray("children");
if (children2 != null) {
for (int i3 = 0; i3 < children2.size(); i3++) {
JSONObject jsonObject3 = children2.getJSONObject(i3);
String code3 = jsonObject3.getString("code");
String name3 = jsonObject3.getString("name");
String sql3 = "insert into region(code, name, pid) values('"+code3+"', '"+name3+"', '"+code2+"');";
// System.out.println(sql3);
writer.write(sql3);
writer.write("\r\n");
writer.close();
}
生成的效果如下:
insert into region(code, name, pid) values('11', '北京市', '0');
insert into region(code, name, pid) values('1101', '市辖区', '11');
insert into region(code, name, pid) values('110101', '东城区', '1101');
insert into region(code, name, pid) values('110101001', '东华门街道', '110101');
insert into region(code, name, pid) values('110101002', '景山街道', '110101');
insert into region(code, name, pid) values('110101003', '交道口街道', '110101');
insert into region(code, name, pid) values('110101004', '安定门街道', '110101');
insert into region(code, name, pid) values('110101005', '北新桥街道', '110101');
insert into region(code, name, pid) values('110101006', '东四街道', '110101');
insert into region(code, name, pid) values('110101007', '朝阳门街道', '110101');
这里为了省事直接用嵌套的for循环了,生成sql文件以后直接用sql工具运行即可,需要提前创建好数据库表。
我知道你们懒,所以直接分享文件给你们吧,好用的话点个关注哦!
链接:https://pan.baidu.com/s/1zjBtlzV_EKuZwf_8gYILCA 密码:a7om
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs