原题如下:

解题代码如下:

table1类:

 @Data
@NoArgsConstructor
@AllArgsConstructor
public class table1{
private String num;
private String name;
private String fatherNum;
}

table2类:

 @Data
@NoArgsConstructor
@AllArgsConstructor
public class table2{
private String num;
private String name;
private String sheng;
private String shi;
private String qu;
}

changeTable类:

 @Data
@NoArgsConstructor
@AllArgsConstructor
class Node{
//编号
private String num;
//名称
private String name;
//父节点
private Node fatherNum;
//子节点树
private List<Node> sonNum;
}
@Data
public class changeTable {
//零散节点,key为编号
private Map<String,Node> MapData = new HashMap<>();
//结构同HashMap,list中存储的每个节点其形状都为树形,其中根为省节点
private List<Node> treeData = new ArrayList<>();
//处理完后生成的新表
private List<table2> tab = new ArrayList<>();
private void createTree(List<table1> datas) {
for(table1 data : datas) {
//为省列,直接添加到treeData中,形成树根
if(data.getFatherNum()==null) {
treeData.add(MapData.get(data.getNum()));
}else {
//当前节点中设置父亲点
MapData.get(data.getNum()).setFatherNum(MapData.get(data.getFatherNum()));
//父节点中设置孩子节点
List<Node> sonNum = MapData.get(data.getFatherNum()).getSonNum();
sonNum.add(MapData.get(data.getNum()));
MapData.get(data.getFatherNum()).setSonNum(sonNum);
}
}
}
//生成零散节点,方便获取
private void createMap(List<table1> datas) {
for(table1 data:datas) {
MapData.put(data.getNum(), new Node(data.getNum(),data.getName(),new Node(),new ArrayList<Node>()));
}
}
//生成新表数据
private void createTable2() {
for(Node node : treeData) {
//node为树根,0为深度
createRow(node,);
}
}
//使用深度优先遍历产生数据
private void createRow(Node node,int depth) {
//当能达到第三层(0层:省,1层:市,2层:区,3层:公司名),则新增数据
if(depth==) {
table2 table2 = new table2();
table2.setNum(node.getNum());
table2.setName(node.getName());
table2.setQu(node.getFatherNum().getNum());
table2.setShi(node.getFatherNum().getFatherNum().getNum());
table2.setSheng(node.getFatherNum().getFatherNum().getFatherNum().getNum());
tab.add(table2);
}else {
//遍历当前节点子节点树
for(Node nod : node.getSonNum()) {
createRow(nod,depth+);
}
}
}
public List<table2> getTable2(List<table1> dataList){
createMap(dataList);
createTree(dataList);
createTable2();
return tab;
}
}

Test类:

 public class Test {
public static void main(String[] args) {
//模拟查询数据库
List<table1> dataList = new ArrayList<>();
dataList.add(new table1("","江汉区XXX公司",""));
dataList.add(new table1("","长沙市",""));
dataList.add(new table1("","武汉市",""));
dataList.add(new table1("","岳麓区",""));
dataList.add(new table1("","湖北省",null));
dataList.add(new table1("","岳麓区ZZZ公司",""));
dataList.add(new table1("","湖南省",null));
dataList.add(new table1("","江汉区",""));
dataList.add(new table1("","江汉区YYY公司",""));
//创建转换对象
changeTable changeTable = new changeTable();
//得到转换结果
List<table2> table2s = changeTable.getTable2(dataList);
for(table2 tab :table2s ) {
System.out.println(tab);
}
}
}

算法解析:

注释已经解释的非常详细了,具体过程我就不再叙述了。

其中table1与table2是两个po对象,而@data注解相当于被注解类中所有成员加上了get、set方法,@NoArgsConstructor为无参构造方法,@AllArgsConstructor为全参构造方法。

运行结果:

注意:当数据非常多时,这种设计将不再适用,因为将所有数据加载到内存中会导致栈溢出。这时可以先将数据库中所有省列查询出来,(省列没有上级编号,这就是很好的查询条件);接着循环遍历省列,根据遍历的省查询出下面所有市;然后遍历查询出来的所有市得到市下面的所有区;然后遍历区下面的所有公司,最后组装数据。虽然性能远不如一次性导入数据,但针对于数据量大时是非常好的解决办法。

设计一个A表数据抽取到B表的抽取过程的更多相关文章

  1. 取A表数据,关联B表任意一条数据

     表A=================== AID, AName 1 jack 2 mary 3 lily 表B================== BID, AID, BName 1 1 aaa ...

  2. SQL Server 的表数据简单操作(表数据查询)

    --表数据查询----数据的基本查询-- --数据简单的查询--select * | 字段名[,字段名2, ...] from 数据表名 [where 条件表达式] 例: use 商品管理数据库 go ...

  3. merge源表数据移植到目标表新表数据中

    merge into dbo.ak_SloteCardTimes a using(select RecordID,CardNO,SloteCardTime from dbo.Tb_CardDate b ...

  4. 【database】复制表数据到相同备份表

    目的及由来,因为数据库表都采取逻辑删除isDeleted=true/flase,但是之前有些报表或者其他的sql并没有在sql中指明此条件.为了不影响之前代码,所以: 1.数据库中创建一张相同的表,把 ...

  5. 获取B表数据添加到A表中作为一个下拉列表元素存在

    1.ProductController类里toedit方法内添加: ProductModel product = ProductModel.dao.findById(id); //通过id查找服务类 ...

  6. mysql把A表数据插入到B表数据的几种方法

    web开发中,我们经常需要将一个表的数据插入到另外一个表,有时还需要指定导入字段,设置只需要导入目标表中不存在的记录,虽然这些都可以在程序中拆分成简单sql来实现,但是用一个sql的话,会节省大量代码 ...

  7. java基于xml配置的通用excel单表数据导入组件(一、实际应用过程)

    主要应用技术:poi + betwixt + reflect 一.实际应用过程 1.创建与目标表结构一样,表名为‘{目标表名}_import’的临时表: 2.创建用于存储导入问题数据的表:t_impo ...

  8. 第三方控件netadvantage UltraWebGrid如何生成带加号多级表数据也就是带子表

    1.看代码不解释: ds.Relations.Add("fk", ds.Tables[0].Columns["Id"], ds.Tables[1].Column ...

  9. A表数据插入到B表(表结构不一致)

    D_A  有E\F\H 3字段 D_B 有 A\B\C\D\E\ID 字段 将 D_B 个别字段插入到D_A  表 INSERT INTO  D_A(E,F,H) select B,A,ID from ...

  10. Sql 将A表数据插入到B表

    A表和B表字段不同 --insert into B(Name,PersonalId,Education,IsDel) select Name, PersonId as PersonalId, ( ca ...

随机推荐

  1. CodeForces 367 C Sereja and the Arrangement of Numbers 欧拉回路

    Sereja and the Arrangement of Numbers 题解: ummm. 在一副图中,如果全部点的度数是偶数/只有2个点是奇数,则能一笔画. 考虑图的点数k为奇数的时候,那么每个 ...

  2. Java面试-List中的sort详细解读

    最近看了一些排序相关的文章,因此比较好奇,Java中的排序是如何做的.本片文章介绍的是JDK1.8,List中的sort方法. 先来看看List中的sort是怎么写的: @SuppressWarnin ...

  3. zookeeper学习(零)_安装与启动

    zookeeper学习(零)_安装与启动 最近换了新的电脑,终于买了梦寐以求的macbook.最近也换了新的公司,公司技术栈用到了zookeeper.当然自己也要安装学习下.省的渣渣的我,被鄙视就麻烦 ...

  4. 4.cache每个参数的意义和作用以及工作原理?

    在程序开发过程中,适当使用 Cache 缓存能有效提高程序执行效率.比如一些常常调用的系统公共变量,把它们缓存到 Cache 中,当需要使用它们时,直接从 Cache 中读取,不必每次都从数据库或文件 ...

  5. Android中px dpi dip density densityDpi 的相关说明

    转自:http://www.cnblogs.com/wader2011/archive/2011/11/29/2267490.html 概念解释 名词 解释 Px (Pixel像素) 不同设备显示效果 ...

  6. 【第十篇】easyui-datagrid排序 (转)

    本文体验datagrid的排序. □ 思路 当点击datagrid的标题,视图传递给Controller的Form Data类似这样:page=1&rows=10&sort=Custo ...

  7. 在64位Linux上安装32位gmp大数库

    前期准备: 如果没有安装32位gcc和g++环境的话,可能会导致安装失败,此时请参考上一篇博文 http://www.cnblogs.com/weir007/p/5977759.html,根据系统版本 ...

  8. apache ignite系列(一): 简介

    apache-ignite简介(一) 1,简介 ​ ignite是分布式内存网格的一种实现,其基于java平台,具有可持久化,分布式事务,分布式计算等特点,此外还支持丰富的键值存储以及SQL语法(基于 ...

  9. WebDriver 将浏览器窗口最大化

    package com.entrym.main; import java.io.File; import java.io.IOException; import org.openqa.selenium ...

  10. Linux 笔记 - 第十七章 Linux LVM 逻辑卷管理器

    一.前言 在实际生产中,有时会遇到磁盘分区空间不足的情况,这时候就需要对磁盘进行扩容,普通情况下需要新加一块磁盘,重分区.格式化.数据复制.卸载旧分区.挂载新分区等繁琐的步骤,而且有可能造成数据的丢失 ...