我有一个webapp,它有一个包含自身集合的对象.我正在努力解决如何在MySQL数据库中对此进行建模的问题.它是一个包含子任务列表的Task对象.这是这个类的样子:Task.javapublic class Task{ private int taskID;private...

我有一个webapp,它有一个包含自身集合的对象.我正在努力解决如何在MySQL数据库中对此进行建模的问题.它是一个包含子任务列表的Task对象.这是这个类的样子:
Task.java
public class Task{
private int taskID;
private String name;
private String details;
private List<Task> subTasks
...other properties
public Task(int taskID, String name, String details){
this.taskID = taskID;
this.name = name;
this.details = details;
this.subTasks = new ArrayList<>();
}
Getters and Setters here...
}
通过一些研究并自己思考,我想出了一个可能的解决方案.我有一个UML图的图像,但由于我刚加入而且我的SO代表还不够高,所以无法发布它.所以我尽力用以下字符显示:
--------------------- -------------------
| Task | | SubTaskMap |
--------------------- 1 __∞_|-----------------
| int taskID |----|__∞_|int subTaskID |
| String taskName | |int parentTaskID |
| String taskDetail | -------------------
--------------------
因此,subTaskID和parentTaskID都是表SubTaskMap中的主键以及表Task中的taskID的外键(同样,它们都是Java中的Task对象).据我所知,在此设置中运行查询以查找与parentTaskID关联的所有任务,我将不得不创建Task表的别名.
我在MS Access中对此进行了全部建模,并且为了获得与parentTaskID为5相关联的所有任务的查询,我指定了Task.taskID与SubTaskMap.subTaskID之间的连接以及别名表Task_Copy和SubTaskMap之间的另一个连接,该连接将Task_copy.taskID与SubTaskMap.parentTaskID获得了这样的SQL查询:
SELECT Task.taskName, SubTask.parentTaskID
FROM Task AS Task_Copy INNER JOIN (Task INNER JOIN SubTask ON Task.taskID = SubTask.subTaskID) ON Task_Copy.taskID = SubTask.parentTaskID
WHERE (((SubTask.parentTaskID)=5));
那么这是解决这个问题的好方法还是有更好的方法?
谢谢你的帮助!
解决方法:
我想你有一个Composite pattern的案例.看看这篇文章:
What are the options for storing hierarchical data in a relational database?我会选择邻接列表:
将字段ParentTaskId添加到表中,并完全取消SubTaskMap表.
本文标题为:如何在MySQL数据库中建模保存自身实例的Java对象?


- JVM内存增强之逃逸分析 2023-05-19
- 详解SpringBoot中@ConditionalOnClass注解的使用 2023-03-31
- java实现扫雷游戏入门程序 2022-12-04
- 微信支付 开发账号体系各参数详解 2023-08-02
- Java使用POI实现导出Excel的方法详解 2023-06-10
- 深入了解volatile和Java内存模型 2023-03-31
- 关于JSON解析中获取不存在的key问题 2023-02-19
- MyBatis流式查询的项目实践 2023-04-17
- Java EE实现用户后台管理系统 2022-11-16
- Java常用类之字符串相关类使用详解 2023-04-06