设计一个A表数据抽取到B表的抽取过程
原题如下:

解题代码如下:
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表的抽取过程的更多相关文章
- 取A表数据,关联B表任意一条数据
表A=================== AID, AName 1 jack 2 mary 3 lily 表B================== BID, AID, BName 1 1 aaa ...
- SQL Server 的表数据简单操作(表数据查询)
--表数据查询----数据的基本查询-- --数据简单的查询--select * | 字段名[,字段名2, ...] from 数据表名 [where 条件表达式] 例: use 商品管理数据库 go ...
- merge源表数据移植到目标表新表数据中
merge into dbo.ak_SloteCardTimes a using(select RecordID,CardNO,SloteCardTime from dbo.Tb_CardDate b ...
- 【database】复制表数据到相同备份表
目的及由来,因为数据库表都采取逻辑删除isDeleted=true/flase,但是之前有些报表或者其他的sql并没有在sql中指明此条件.为了不影响之前代码,所以: 1.数据库中创建一张相同的表,把 ...
- 获取B表数据添加到A表中作为一个下拉列表元素存在
1.ProductController类里toedit方法内添加: ProductModel product = ProductModel.dao.findById(id); //通过id查找服务类 ...
- mysql把A表数据插入到B表数据的几种方法
web开发中,我们经常需要将一个表的数据插入到另外一个表,有时还需要指定导入字段,设置只需要导入目标表中不存在的记录,虽然这些都可以在程序中拆分成简单sql来实现,但是用一个sql的话,会节省大量代码 ...
- java基于xml配置的通用excel单表数据导入组件(一、实际应用过程)
主要应用技术:poi + betwixt + reflect 一.实际应用过程 1.创建与目标表结构一样,表名为‘{目标表名}_import’的临时表: 2.创建用于存储导入问题数据的表:t_impo ...
- 第三方控件netadvantage UltraWebGrid如何生成带加号多级表数据也就是带子表
1.看代码不解释: ds.Relations.Add("fk", ds.Tables[0].Columns["Id"], ds.Tables[1].Column ...
- 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 ...
- Sql 将A表数据插入到B表
A表和B表字段不同 --insert into B(Name,PersonalId,Education,IsDel) select Name, PersonId as PersonalId, ( ca ...
随机推荐
- Ubuntu开机出现grub指令,无法正常开机
问题 最近开机出现了如下的界面: 分析问题 首先看看GNU GRUB是什么东东?干什么用的? GNU GRUB是多重引导加载程序.通俗点说,它就是用来一个可以让你选择运行什么操作系统的程序. 在你开机 ...
- cf--703--A-- Mishka and Game
题目链接:http://codeforces.com/problemset/problem/703/A Mishka is a little polar bear. As known, little ...
- Toad客户端连接Oracle数据库报错 ORA-12170:TNS:连接超时
Oracle 客户端连接Oracle数据库报错 ORA-12170:TNS:连接超时 排错步骤: 1. 查看网络是否畅通: 打开cmd,ping数据库IP 2. 查看端口是否畅通: 打开cmd ...
- 相同类中方法间调用时日志Aop失效处理
本篇分享的内容是在相同类中方法间调用时Aop失效处理方案,该问题我看有很多文章描述了,不过大多是从事务角度分享的,本篇打算从日志aop方面分享(当然都是aop,失效和处理方案都是一样),以下都是基于s ...
- git bash 界面修改成linux界面
在使用git bash操作git时,$符总是另起一行,给人感觉特别不爽,特别想修改成linux下一样的风格. 在git输入命令: vim ~/.bash_profile 进入insert模式,添加内容 ...
- 开发必配的Finder设置
1.显示标签页.显示路径栏.显示状态栏的设置位置,在访达->显示-> 显示状态栏 个人三个都设置了,但是觉得显示状态栏用的并不多,反而多一行,下面是显示状态栏的效果,主要可以一眼看出有多少 ...
- Istio 1.3 发布,HTTP 遥测不再需要 Mixer
原文链接:Istio 1.3 发布,HTTP 遥测不再需要 Mixer Istio 是 Google.IBM 和 Lyft 联合开源的服务网格(Service Mesh)框架,旨在解决大量微服务的发现 ...
- HBase WAL原理学习
1.概述 客户端往RegionServer端提交数据的时候,会写WAL日志,只有当WAL日志写成功以后,客户端才会被告诉提交数据成功,如果写WAL失败会告知客户端提交失败,换句话说这其实是一个数据落地 ...
- STL中的unique和unique_copy函数
一.unique函数 这个函数的功能就是删除相邻的重复元素,然后重新排列输入范围内的元素,并返回一个最后一个无重复值的迭代器(并不改变容器长度). 例如: vector<); ; i < ...
- 强大的时间处理库 moment
中文文档: http://momentjs.cn/docs/ 常用方法 1.当前时间对象 moment () / 指定时间对象 moment("2019-09-19 08:00:0 ...