我有一个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对象?
基础教程推荐
- java锁机制ReentrantLock源码实例分析 2023-06-09
- JSP组件commons-fileupload实现文件上传 2023-08-02
- Java实现直接插入排序与折半插入排序的示例详解 2023-02-10
- 动态上传jar包热部署的实战详解 2023-06-06
- SpringMVC下获取验证码实例详解 2023-07-30
- Java Swing编写一个简单的计算器软件 2023-08-10
- 分享Spring Cloud OpenFeign 的五个优化技巧 2022-11-08
- Java使用HttpClient实现文件下载 2023-04-12
- Java多线程Thread类的使用及注意事项 2023-01-18
- Java ArrayList类的基础使用讲解 2023-06-23