一,数据源

1.1,数据库查出来的数据是

两张表先各自左外连接,然后在相互左外连接查找省市县的数据(业务需求必须这样做,省市去的是第一张表,而市县取的是第二张表,两张表中间通过市的名字连接)见这个博文的最后一张图片

1.2,要求转换成的json格式的数据

1.2.1,完整数据

json省市县数据源(这是全部的数据)

1.2.2,抽取的数据

 [
     {
         "Code": "410000",
         "Name": "河南省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "郑州市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "二七区",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "中原区",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "新乡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "卫滨区",
                         "sort": 1
                     },
                     {
                         "Code": "414530",
                         "Name": "牧野区",
                         "sort": 2
                     }
                 ],
                 "sort": 2
             }
         ]
     },
     {
         "Code": "410000",
         "Name": "陕西省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "汉中市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "西乡县",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "南郑县",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "宝鸡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "岐山县",
                         "sort": 1
                     },
                     {
                         "Code": "414530",
                         "Name": "芙蓉县",
                         "sort": 2
                     }
                 ],
                 "sort": 2
             }
         ]
     }
 ]

二,转化的整体代码

2.1,代码总览

   /**
      * 查询省份城市区县
      *
      * @return
      */
     public String queryFullZoneInfo() {
         List<Map<String, String>> mapList = zoneInfoService.queryFullZoneInfo();
         List<Map<String, Object>> zoneList = new ArrayList<Map<String, Object>>();
         Map<String, Object> existMap = new HashMap<String, Object>();
         for (Map<String, String> map : mapList) {
             String province = map.get("province");
             Map<String, Object> provinceMap = null;
             if (existMap.containsKey(province)) {
                 provinceMap = (Map<String, Object>) existMap.get(province);
             } else {
                 provinceMap = new HashMap<String, Object>();
                 existMap.put(province, provinceMap);
                 zoneList.add(provinceMap);
             }

             provinceMap.put("Code", map.get("provinceCode"));
             provinceMap.put("Name", map.get("province"));
             String city = map.get("city");
             if (StringUtils.isNotEmpty(city)) {
                 List<Map<String, Object>> provinceCityList = null;
                 if (existMap.containsKey(province + "_")) {
                     provinceCityList = (List<Map<String, Object>>) existMap.get(province + "_");
                 } else {
                     provinceCityList = new ArrayList<Map<String, Object>>();
                     existMap.put(province + "_", provinceCityList);
                     provinceMap.put("level", provinceCityList);
                 }
                 Map<String, Object> provinceCityMap = null;
                 if (existMap.containsKey(province + "_" + city)) {
                     provinceCityMap = (Map<String, Object>) existMap.get(province + "_" + city);
                 } else {
                     provinceCityMap = new HashMap<String, Object>();
                     existMap.put(province + "_" + city, provinceCityMap);
                     provinceCityList.add(provinceCityMap);
                     String citySort = String.valueOf(existMap.get(province + "_sort"));
                     existMap.put(province + "_sort", "null".equals(citySort) ? 1 : NumberUtils.toInt(citySort) + 1);
                     provinceCityMap.put("sort", existMap.get(province + "_sort"));
                 }

                 provinceCityMap.put("Name", city);
                 provinceCityMap.put("Code", map.get("cityCode"));

                 List<Map<String, Object>> provinceCityCountryList = null;
                 if (existMap.containsKey(province + "_" + city + "_")) {
                     provinceCityCountryList = (List<Map<String, Object>>) existMap.get(province + "_" + city + "_");
                 } else {
                     provinceCityCountryList = new ArrayList<Map<String, Object>>();
                     existMap.put(province + "_" + city + "_", provinceCityCountryList);
                     provinceCityMap.put("level", provinceCityCountryList);
                 }

                 String country = map.get("country");
                 Map<String, Object> provinceCityCountryMap = null;
                 if (StringUtils.isNotEmpty(country)) {
                     if (existMap.containsKey(province + "_" + city + "_" + country)) {
                         provinceCityCountryMap = (Map<String, Object>) existMap.get(province + "_" + city + "_" + country);
                     } else {
                         provinceCityCountryMap = new HashMap<String, Object>();
                         existMap.put(province + "_" + city + "_" + country, provinceCityCountryMap);
                         provinceCityCountryList.add(provinceCityCountryMap);
                         String countrySort = String.valueOf(existMap.get(province + "_" + city + "_sort"));
                         existMap.put(province + "_" + city + "_sort", "null".equals(countrySort) ? 1 : NumberUtils.toInt(countrySort) + 1);
                         provinceCityCountryMap.put("sort", existMap.get(province + "_" + city + "_sort"));
                     }

                     provinceCityCountryMap.put("Code", map.get("countryCode"));
                     provinceCityCountryMap.put("Name", country);
                 } else {
                     provinceCityCountryMap = new HashMap<String, Object>();
                     provinceCityCountryList.add(provinceCityCountryMap);
                     provinceCityCountryMap.put("sort", 1);
                     provinceCityCountryMap.put("Code", "");
                     provinceCityCountryMap.put("Name", "");
                 }
             }
         }

         try {
             return JsonUtils.toJson(zoneList);
         } catch (Exception e) {
             e.printStackTrace();
         }

         return null;
     }

三,代码解析

3.1,json格式数据分析

从1.2.2的数据我们可以看到这个json所要求的数据是这个样子的

3.1.1,list

第一个大的list里面装的是34个省的对象组成的一个list集合。

3.1.2,map(对象)

每一个省中有code,和name的键值对,还有一个level的list集合

3.1.3,list

就是上面所说的level的集合,这个集合当中装的是每一个省里面的地级市的map对象

3.1.4,map(对象)

map对象里面有code,name的键值对,还有一个level的list集合,此外还有一个代表顺序的sort标示符

3.1.5,list

就是上面所说的level的集合,这个集合当中装的是每一个地级市里面装的县城的map对象

3.1.6,map(对象)

map对象里面有code,name的键值对,此外还有一个代表顺序的sort标示符,注意这个里面是没有list的集合了,因为它已经是最后一层了。

3.2,java代码分析

3.2.1,代码初步实现

根据上面的代码我们可以写出这样的代码

  public String queryFullZoneInfo() {
         List<Map<String, String>> mapList = zoneInfoService.queryFullZoneInfo();
         List<Map<String, Object>> zoneList = new ArrayList<Map<String, Object>>();
         Map<String, Object> existMap = new HashMap<String, Object>();
         Map<String, Object> provinceMap = new HashMap<String, Object>();
         Map<String, Object> provinceCityMap = new HashMap<String, Object>();
         List<Map<String, Object>> provinceCityList = new ArrayList<Map<String, Object>>();
         List<Map<String, Object>> provinceCityCountryList = new ArrayList<Map<String, Object>>();
         Map<String, Object> provinceCityCountryMap = new HashMap<String, Object>();
         for (Map<String, String> map : mapList) {
         zoneList = new ArrayList<Map<String, Object>>();
          provinceMap = new HashMap<String, Object>();
           provinceCityMap = new HashMap<String, Object>();
             provinceMap.put("Code", map.get("provinceCode"));
             provinceCityList = new ArrayList<Map<String, Object>>();
             provinceCityCountryList = new ArrayList<Map<String, Object>>();
             provinceCityCountryMap = new HashMap<String, Object>();
             provinceMap.put("Name", map.get("province"));

provinceMap.put("level", provinceCityList);

provinceCityList.add(provinceCityMap);

provinceCityMap.put("Name", map.get("city")); provinceCityMap.put("Code", map.get("cityCode"));

provinceCityMap.put("level", provinceCityCountryList);

provinceCityCountryList.add(provinceCityCountryMap);

provinceCityCountryMap.put("Code", map.get("countryCode")); provinceCityCountryMap.put("Name", map.get("country")); zoneList.add(provinceMap); } try { return JsonUtils.toJson(zoneList); } catch (Exception e) { e.printStackTrace(); }

注意上面空开的空格是和4.2做对比用的。

3.2.2,注意点

在上面的代码中虽然provinceMap是先把provinceCityList给put进去的,但是这不影响后面provinceCityList的取值,换句话就是当执行到这句

provinceMap.put("level", provinceCityList);

代码的时候,provinceCityList是null,只到这句代码

provinceCityList.add(provinceCityMap);
provinceCityMap.put("Name", map.get("city"));
provinceCityMap.put("Code", map.get("cityCode"));

执行完之后它才有的值,但同时注意了,provinceMap里面的provinceCityList也就有了值,这是后面给它赋值的。

3.2.3,注意点升级

 String province = map.get("province");
             Map<String, Object> provinceMap = null;
             if (existMap.containsKey(province)) {
                 provinceMap = (Map<String, Object>) existMap.get(province);
             } else {
                 provinceMap = new HashMap<String, Object>();
                 existMap.put(province, provinceMap);{黑龙江省={Name=黑龙江省, Code=230000}}
                 zoneList.add(provinceMap);
             }

             provinceMap.put("Code", map.get("provinceCode"));
             provinceMap.put("Name", map.get("province"));
             注意理解上面的代码:
             是先申明了一个map,注意第一遍走的时候existMap.put(province, provinceMap);它是空的
             但是当走到provinceMap.put("Code", map.get("provinceCode"));
             provinceMap.put("Name", map.get("province"));这两行的时候它会把值给塞进去,
             这时候existMap里面有值了
             即使如果不走else里面的语句,也会把值给塞进去的。

3.2.4,问题点

假如像上面那样去解决问题的话,那么后面的代码永远会把前面的代码给覆盖掉的,

因为每一次都是new的一个对象。所以到最后上万条的数据,只会出来最后一条数据,

比如我测试的结果

 [
     {
         "Code": "310000",
         "Name": "上海市",
         "level": [
             {
                 "Code": "310100",
                 "Name": "上海市",
                 "level": [
                     {
                         "Code": "2909",
                         "Name": "长宁区"
                     }
                 ]
             }
         ]
     }
 ]

最后返回的就是这一条数据,完全不是自己要的东西。

四,解决方法

4.1,代码

和2.1的代码是一么一样的。

4.2,注意点

这句代码就是在原来的基础上加了一个existMap的双例集合

我们把2.1的代码分开来读就会更加清晰

 if (existMap.containsKey(province + "_")) {
                     provinceCityList = (List<Map<String, Object>>) existMap.get(province + "_");
                 } else {
                     provinceCityList = new ArrayList<Map<String, Object>>();
                     existMap.put(province + "_", provinceCityList);
                     provinceMap.put("level", provinceCityList);
                 }
 if (existMap.containsKey(province + "_" + city)) {
                     provinceCityMap = (Map<String, Object>) existMap.get(province + "_" + city);
                 } else {
                     provinceCityMap = new HashMap<String, Object>();
                     existMap.put(province + "_" + city, provinceCityMap);
                     provinceCityList.add(provinceCityMap);
                     String citySort = String.valueOf(existMap.get(province + "_sort"));
                     existMap.put(province + "_sort", "null".equals(citySort) ? 1 : NumberUtils.toInt(citySort) + 1);
                     provinceCityMap.put("sort", existMap.get(province + "_sort"));
                 }
 if (existMap.containsKey(province + "_" + city + "_")) {
                     provinceCityCountryList = (List<Map<String, Object>>) existMap.get(province + "_" + city + "_");
                 } else {
                     provinceCityCountryList = new ArrayList<Map<String, Object>>();
                     existMap.put(province + "_" + city + "_", provinceCityCountryList);
                     provinceCityMap.put("level", provinceCityCountryList);
                 }
 if (existMap.containsKey(province + "_" + city + "_" + country)) {
                         provinceCityCountryMap = (Map<String, Object>) existMap.get(province + "_" + city + "_" + country);
                     } else {
                         provinceCityCountryMap = new HashMap<String, Object>();
                         existMap.put(province + "_" + city + "_" + country, provinceCityCountryMap);
                         provinceCityCountryList.add(provinceCityCountryMap);
                         String countrySort = String.valueOf(existMap.get(province + "_" + city + "_sort"));
                         existMap.put(province + "_" + city + "_sort", "null".equals(countrySort) ? 1 : NumberUtils.toInt(countrySort) + 1);
                         provinceCityCountryMap.put("sort", existMap.get(province + "_" + city + "_sort"));
                     }

4.3,解析existMap作用

因为假如现在没有这个map集合就会产生覆盖的作用,现在这个map的作用就是把取出来的值以不同的名字取出来放到map集合中来,假如下一次再去取的时候如果有就不在新建对象了,直接用原来的就行了,如果没有在建立新的对象。

这就解决了覆盖的问题。

同时也给sort排上了序号。

用下面的例子来说明

有就取原来的,没有就新建,这样的话就会把后面新的数据加到前面有的数据里面
举个例子,假如现在是河南省map1里面有name,code,和sort,leval集合,第一遍是地级市是安阳,当第二遍循环的时候,还是取省份这时候还是河南省,就不会新建一个map了,而是还是取原来的map1,这时候假如是新乡市,就会把新乡市,同样加在这个map当中,这样一个map当中就会有两个leval了
假如现在不是河南省了,而是陕西省了,就会新建一个map2,会把它里面的数据加载这个map2当中,
map1,map2装在一个list中返回,就有效的避免了第一种情况的产生了。

其中市县和上面也是同样的道理。

注意这个existMap里面装的数据会特别的多,比返回的provinceMap大了几万倍呢。

我们以上面的json的数据来手动遍历几遍。

4.3.1,首次遍历

 {
     "Code": "410000",
     "Name": "河南省",
     "level": [
         {
             "Code": "414500",
             "Name": "郑州市",
             "level": [
                 {
                     "Code": "414500",
                     "Name": "二七区",
                     "sort": 1
                 }
             ],
             "sort": 1
         }
     ]
 }

4.3.2,2遍

 {
     "Code": "410000",
     "Name": "河南省",
     "level": [
         {
             "Code": "414500",
             "Name": "郑州市",
             "level": [
                 {
                     "Code": "414500",
                     "Name": "二七区",
                     "sort": 1
                 },
                 {
                     "Code": "414500",
                     "Name": "中原区",
                     "sort": 2
                 }
             ],
             "sort": 1
         }
     ]
 }

4.3.3,3遍

 {
     "Code": "410000",
     "Name": "河南省",
     "level": [
         {
             "Code": "414500",
             "Name": "郑州市",
             "level": [
                 {
                     "Code": "414500",
                     "Name": "二七区",
                     "sort": 1
                 },
                 {
                     "Code": "414500",
                     "Name": "中原区",
                     "sort": 2
                 }
             ],
             "sort": 1
         },
         {
             "Code": "414530",
             "Name": "新乡市",
             "level": [
                 {
                     "Code": "414530",
                     "Name": "卫滨区",
                     "sort": 1
                 }
             ],
             "sort": 2
         }
     ]
 }

4.3.4,4遍

 {
     "Code": "410000",
     "Name": "河南省",
     "level": [
         {
             "Code": "414500",
             "Name": "郑州市",
             "level": [
                 {
                     "Code": "414500",
                     "Name": "二七区",
                     "sort": 1
                 },
                 {
                     "Code": "414500",
                     "Name": "中原区",
                     "sort": 2
                 }
             ],
             "sort": 1
         },
         {
             "Code": "414530",
             "Name": "新乡市",
             "level": [
                 {
                     "Code": "414530",
                     "Name": "卫滨区",
                     "sort": 1
                 },
                 {
                     "Code": "414530",
                     "Name": "牧野区",
                     "sort": 2
                 }
             ],
             "sort": 2
         }
     ]
 }

4.3.5,5遍

 [
     {
         "Code": "410000",
         "Name": "河南省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "郑州市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "二七区",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "中原区",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "新乡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "卫滨区",
                         "sort": 1
                     },
                     {
                         "Code": "414530",
                         "Name": "牧野区",
                         "sort": 2
                     }
                 ],
                 "sort": 2
             }
         ]
     },
     {
         "Code": "410000",
         "Name": "陕西省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "汉中市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "西乡县",
                         "sort": 1
                     }
                 ],
                 "sort": 1
             }
         ]
     }
 ]

4.3.6,6遍

 [
     {
         "Code": "410000",
         "Name": "河南省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "郑州市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "二七区",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "中原区",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "新乡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "卫滨区",
                         "sort": 1
                     },
                     {
                         "Code": "414530",
                         "Name": "牧野区",
                         "sort": 2
                     }
                 ],
                 "sort": 2
             }
         ]
     },
     {
         "Code": "410000",
         "Name": "陕西省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "汉中市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "西乡县",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "南郑县",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             }
         ]
     }
 ]

4.3.7,7遍

 [
     {
         "Code": "410000",
         "Name": "河南省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "郑州市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "二七区",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "中原区",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "新乡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "卫滨区",
                         "sort": 1
                     },
                     {
                         "Code": "414530",
                         "Name": "牧野区",
                         "sort": 2
                     }
                 ],
                 "sort": 2
             }
         ]
     },
     {
         "Code": "410000",
         "Name": "陕西省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "汉中市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "西乡县",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "南郑县",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "宝鸡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "岐山县",
                         "sort": 1
                     }
                 ],
                 "sort": 2
             }
         ]
     }
 ]

4.3.8,8遍

 [
     {
         "Code": "410000",
         "Name": "河南省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "郑州市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "二七区",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "中原区",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "新乡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "卫滨区",
                         "sort": 1
                     },
                     {
                         "Code": "414530",
                         "Name": "牧野区",
                         "sort": 2
                     }
                 ],
                 "sort": 2
             }
         ]
     },
     {
         "Code": "410000",
         "Name": "陕西省",
         "level": [
             {
                 "Code": "414500",
                 "Name": "汉中市",
                 "level": [
                     {
                         "Code": "414500",
                         "Name": "西乡县",
                         "sort": 1
                     },
                     {
                         "Code": "414500",
                         "Name": "南郑县",
                         "sort": 2
                     }
                 ],
                 "sort": 1
             },
             {
                 "Code": "414530",
                 "Name": "宝鸡市",
                 "level": [
                     {
                         "Code": "414530",
                         "Name": "岐山县",
                         "sort": 1
                     },
                     {
                         "Code": "414530",
                         "Name": "芙蓉县",
                         "sort": 2
                     }
                 ],
                 "sort": 2
             }
         ]
     }
 ]

致此一个流程走完就大概知道它的一个流程了。

五,优化

5.1,优化一

因为existMap数据是特别大的,所以每当我们遍历完一个省份之后就把里面的数据清除

 String province = map.get("province");
             Map<String, Object> provinceMap = null;
             if(province!=existMap.get("province")){
                 existMap.clear();
             }
             

拿这一次的取出来的province和existMap里面的province对比,假如有就继续遍历,假如没有就说明换省份了,清空exitMap,这样会提升效率。

5.2,优化二

最后一次就不用王existMap里面放值了,因为我们知道没遍历一次省市可能一样,但是县绝对是不一样的。

     String country = map.get("country");
                 Map<String, Object> provinceCityCountryMap = null;
                 if (StringUtils.isNotEmpty(country)) {

                         provinceCityCountryMap = new HashMap<String, Object>();
                         provinceCityCountryList.add(provinceCityCountryMap);
                         String countrySort = String.valueOf(existMap.get(province + "_" + city + "_sort"));
                         existMap.put(province + "_" + city + "_sort", "null".equals(countrySort) ? 1 : NumberUtils.toInt(countrySort) + 1);
                         provinceCityCountryMap.put("sort", existMap.get(province + "_" + city + "_sort"));

                     provinceCityCountryMap.put("Code", map.get("countryCode"));
                     provinceCityCountryMap.put("Name", country);

5.3,优化完之后完整的代码

   public String queryFullZoneInfo() {
         List<Map<String, String>> mapList = zoneInfoService.queryFullZoneInfo();
         List<Map<String, Object>> zoneList = new ArrayList<Map<String, Object>>();
         Map<String, Object> existMap = new HashMap<String, Object>();
         for (Map<String, String> map : mapList) {
             String province = map.get("province");
             Map<String, Object> provinceMap = null;
             if(province!=existMap.get("province")){
                 existMap.clear();
             }

             if (existMap.containsKey(province)) {
                 provinceMap = (Map<String, Object>) existMap.get(province);
             } else {
                 provinceMap = new HashMap<String, Object>();
                 existMap.put(province, provinceMap);
                 zoneList.add(provinceMap);
             }

             provinceMap.put("Code", map.get("provinceCode"));
             provinceMap.put("Name", map.get("province"));
             String city = map.get("city");
             if (StringUtils.isNotEmpty(city)) {
                 List<Map<String, Object>> provinceCityList = null;
                 if (existMap.containsKey(province + "_")) {
                     provinceCityList = (List<Map<String, Object>>) existMap.get(province + "_");
                 } else {
                     provinceCityList = new ArrayList<Map<String, Object>>();
                     existMap.put(province + "_", provinceCityList);
                     provinceMap.put("level", provinceCityList);
                 }
                 Map<String, Object> provinceCityMap = null;
                 if (existMap.containsKey(province + "_" + city)) {
                     provinceCityMap = (Map<String, Object>) existMap.get(province + "_" + city);
                 } else {
                     provinceCityMap = new HashMap<String, Object>();
                     existMap.put(province + "_" + city, provinceCityMap);
                     provinceCityList.add(provinceCityMap);
                     String citySort = String.valueOf(existMap.get(province + "_sort"));
                     existMap.put(province + "_sort", "null".equals(citySort) ? 1 : NumberUtils.toInt(citySort) + 1);
                     provinceCityMap.put("sort", existMap.get(province + "_sort"));
                 }

                 provinceCityMap.put("Name", city);
                 provinceCityMap.put("Code", map.get("cityCode"));

                 List<Map<String, Object>> provinceCityCountryList = null;
                 if (existMap.containsKey(province + "_" + city + "_")) {
                     provinceCityCountryList = (List<Map<String, Object>>) existMap.get(province + "_" + city + "_");
                 } else {
                     provinceCityCountryList = new ArrayList<Map<String, Object>>();
                     existMap.put(province + "_" + city + "_", provinceCityCountryList);
                     provinceCityMap.put("level", provinceCityCountryList);
                 }

                 String country = map.get("country");
                 Map<String, Object> provinceCityCountryMap = null;
                 if (StringUtils.isNotEmpty(country)) {

                         provinceCityCountryMap = new HashMap<String, Object>();
                         provinceCityCountryList.add(provinceCityCountryMap);
                         String countrySort = String.valueOf(existMap.get(province + "_" + city + "_sort"));
                         existMap.put(province + "_" + city + "_sort", "null".equals(countrySort) ? 1 : NumberUtils.toInt(countrySort) + 1);
                         provinceCityCountryMap.put("sort", existMap.get(province + "_" + city + "_sort"));

                     provinceCityCountryMap.put("Code", map.get("countryCode"));
                     provinceCityCountryMap.put("Name", country);
                 } else {
                     provinceCityCountryMap = new HashMap<String, Object>();
                     provinceCityCountryList.add(provinceCityCountryMap);
                     provinceCityCountryMap.put("sort", 1);
                     provinceCityCountryMap.put("Code", "");
                     provinceCityCountryMap.put("Name", "");
                 }
             }
         }

         try {
             return JsonUtils.toJson(zoneList);
         } catch (Exception e) {
             e.printStackTrace();
         }

         return null;
     }
     

5.4

省市县从数据库读出来的list数据转换成json格式的数据的更多相关文章

  1. PHP将数据库的数据转换成json格式

    header('content-type:application/json;charset=utf8');  $results = array();     while ($row = mysql_f ...

  2. django-将数据库数据转换成JSON格式(ORM和SQL两种情况)

    最近打算搞一个自动化运维平台,所以在看Django的知识. 在实际项目开发中,遇到一个小问题:前后端发生数据交互主流采用的是JSON.前端传数据到服务器端比较简单,稍微麻烦的是服务器端传JSON到前端 ...

  3. 数据库获取map数据后转化成json格式的数据

    一,从数据库查出来的数据 两张表先各自左外连接,然后在相互左外连接查找省市县的数据(业务需求必须这样做,省市去的是第一张表,而市县取的是第二张表,两张表中间通过市的名字连接)见这个博文的最后一张图片 ...

  4. 数据库记录转换成json格式 (2011-03-13 19:48:37) (转)

    http://blog.sina.com.cn/s/blog_621768f30100r6v7.html 数据库记录转换成json格式 (2011-03-13 19:48:37) 转载▼ 标签: 杂谈 ...

  5. 用java代码将从数据库中取出的具有父子关系的数据转成json格式

    思路:①.取出数据中的所有父节点放入一个集合中②.取出数据中所有为该父节点的子节点放入另一个集合中③.用到迭代的方法将子节点一层一层的遍历工具类:package com.assasion.test;i ...

  6. DELPHI 把数据库中的数据转换成XML格式

    function ReplaceString(AString: string): string; begin Result := StringReplace(AString, '&', '&a ...

  7. 将 数据库中的结果集转换为json格式(三)

    从数据库中得到结果集 public String list() throws Exception { Connection con = null; PageBean pageBean = new Pa ...

  8. 读取mysql数据库的数据,转为json格式

    # coding=utf-8 ''' Created on 2016-10-26 @author: Jennifer Project:读取mysql数据库的数据,转为json格式 ''' import ...

  9. C++ OCCI API数据库操作之连接、返回查询结果集为json格式

    使用C++操作数据库,转换返回结果集为json格式,易于解析. 以下程序的编译.运行环境:Windows 10 1803.VS2017 17.5.2(vc14).解决方案配置:Release.解决方案 ...

随机推荐

  1. 51NOD 1584 加权约数和 [莫比乌斯反演 转化 Trick]

    1584 加权约数和 题意:求\(\sum_{i=1}^{N} \sum_{j=1}^{N} {\max(i,j)\cdot \sigma(i\cdot j)}\) 多组数据\(n \le 10^6, ...

  2. s5pv210 的启动

    1.开发板已启动从0x0获取数据(内部64k的硬盘,里面含有三星固化的BL0段代码),将其读到a8软核中,进行运算,主要用于初始化时钟,96k的内部IRAM.并负责 指定启动设备(通常为外部硬盘),从 ...

  3. PLECS—直流电机系统2

    1.模型图 2,计算及仿真 1)计算   2)仿真 n = 1870.1 r/min (wm = 195.833 rad/s)                                     ...

  4. codeforces 940D 比赛总结

    这次比赛总体还行,但是并没发挥到极致 A题 速度正常 题解 B题 这个题先是没注意时间复杂度,tle了,好不容易优化了没多测几组就交了,很开心的wa了,查了一边发现没特判k,改好后有草率地交了,又wa ...

  5. 940D Alena And The Heater

    传送门 题目大意 给出两个长度为N的数组A,B,以及一种计算规律: 若t[i]=1,需满足t[i-1]=t[i-2]=t[i-3]=t[i-4]=0,以及max{A[i],A[i-1],A[i-2], ...

  6. 高可用的MongoDB集群

    1.序言 MongoDB 是一个可扩展的高性能,开源,模式自由,面向文档的数据库. 它使用 C++编写.MongoDB 包含一下特点: l  面向集合的存储:适合存储对象及JSON形式的数据. l ...

  7. jdbc 报错解决办法

    刚刚看到一个童鞋出现了这个问题 其实这个问题很好解决 在工程中创建一个lib目录: 然后讲mysql包复制进去 然后对着包点击右键 build path就可以了 最后面再次运行就可以了 jar包地址下 ...

  8. Android查缺补漏(IPC篇)-- 进程间通讯之Socket简介及示例

    本文作者:CodingBlock 文章链接:http://www.cnblogs.com/codingblock/p/8425736.html 进程间通讯篇系列文章目录: Android查缺补漏(IP ...

  9. 机器学习实战 之 KNN算法

    现在 机器学习 这么火,小编也忍不住想学习一把.注意,小编是零基础哦. 所以,第一步,推荐买一本机器学习的书,我选的是Peter harrigton 的<机器学习实战>.这本书是基于pyt ...

  10. Java语言的分支

    JavaSE:(标准版)是java基础,早期叫j2se,2005改名叫JavaSE(必须). JavaME:(移动版)适合移动端的开发.j2me,2005改名叫java ME(不学) JavaEE:( ...