算法:将table标识的树形结构文本数据快速导入Mysql邻接表
来源:互联网 发布:qq空间网络音乐 编辑:程序博客网 时间:2024/04/30 16:03
问题:请根据题干描述你的算法,有以下树形结构的文本数据:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
部门A
职员1
职员2
部门B
职员3
职员4
部门C
职员5
职员6
部门A
职员1
职员2
部门B
职员3
职员4
部门C
职员5
职员6
它们用最常用的table符号标识其数据结构,请使用PHP计算出每条数据的路径、是否是叶子节点并导入一张邻接表。
答案:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
//使用换行符号分割数组
$arr = explode(PHP_EOL, PHP_EOL . $str);
//用来存储路径的数组
$pathArr = array();
//储存结果的数组
$reArr = array();
//辅助变量
$lastPos = $lastPosPre = 0;
foreach ($arr as $id => $v){
//\t出现的次数
$lastPos = strrpos ($v, "\t");
$lastPos = ($lastPos === FALSE)?0:$lastPos+1;
//将路径压入数组
$pathArr[$lastPos] = $id;
//计算出当前路径
$path = array_slice ($pathArr, 0, $lastPos);
//计算父级id
$pid = (int) isset ($pathArr[$lastPos - 1]) ? $pathArr[$lastPos - 1] : 0;
//首次循环丢弃
if ($id == 0){continue;}
//要写入数据库的数据
$reArr[$id] = array(
'id' => $id,
'pid' => $pid,
'is_leaf' => 1,
'path' => '/' . implode('/', $path),
'name' => ltrim($v, "\t")
);
//是否叶子节点
if ($lastPos > $lastPosPre) {
$reArr[$id-1]['is_leaf'] = 0;
}
//上一节循环中,\t出现的次数
$lastPosPre = $lastPos;
}
//使用换行符号分割数组
$arr = explode(PHP_EOL, PHP_EOL . $str);
//用来存储路径的数组
$pathArr = array();
//储存结果的数组
$reArr = array();
//辅助变量
$lastPos = $lastPosPre = 0;
foreach ($arr as $id => $v){
//\t出现的次数
$lastPos = strrpos ($v, "\t");
$lastPos = ($lastPos === FALSE)?0:$lastPos+1;
//将路径压入数组
$pathArr[$lastPos] = $id;
//计算出当前路径
$path = array_slice ($pathArr, 0, $lastPos);
//计算父级id
$pid = (int) isset ($pathArr[$lastPos - 1]) ? $pathArr[$lastPos - 1] : 0;
//首次循环丢弃
if ($id == 0){continue;}
//要写入数据库的数据
$reArr[$id] = array(
'id' => $id,
'pid' => $pid,
'is_leaf' => 1,
'path' => '/' . implode('/', $path),
'name' => ltrim($v, "\t")
);
//是否叶子节点
if ($lastPos > $lastPosPre) {
$reArr[$id-1]['is_leaf'] = 0;
}
//上一节循环中,\t出现的次数
$lastPosPre = $lastPos;
}
这份答案,可以导入无限深的树形结构数据。不过未经优化,等已有有时间再琢磨琢磨。
- 算法:将table标识的树形结构文本数据快速导入Mysql邻接表
- 算法:将table标识的树形结构文本数据快速导入Mysql邻接表
- 将excel树形结构的数据导入数据库
- mysql将格式化文本数据导入数据库
- mysql存储树形结构的数据
- 分别采用深度和广度遍历数据库中邻接表中存储的树形结构的数据
- mysql树形结构表设计(Path Enumerations,Closure Table)
- mysql导入文本数据
- 将树形结构生成文本,并输出
- 如何将数据从文本导入到mysql
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- 使用MySQL Migration Toolkit快速将Oracle数据导入MySQL
- Regional 2011, Asia - Kuala Lumpur 解题报告
- 关于php_apc的一个疑问
- Android源码编译 首发ViVo Xplay X510w 2.14.8 完美root/美颜相机/状态栏美化/支持官方OTA/纯净,稳定ROM
- Delphi for iOS开发指南(7):在iOS应用程序中使用WebBrowser组件
- ztree的使用
- 算法:将table标识的树形结构文本数据快速导入Mysql邻接表
- 表单提交数据请求 get和post的 区别
- 个人网站如何在互联网时代下求生存
- WPF TreeView HierarchicalDataTemplate
- 提高你的Java代码质量吧:在switch的default代码块中增加AssertionError错误
- PagerHelper for ASP.NET MVC3
- CoreAudio实现录音播音和扬声器听筒模式的切换
- Redis配置文件详解
- think in java interview-高级开发人员面试宝典(一)