我有一个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+mysql实现学籍管理系统 2023-03-16
- 运用El表达式截取字符串/获取list的长度实例 2023-08-01
- Java中EnvironmentAware 接口的作用 2023-01-23
- 是否适合从javabean类更新数据库? 2023-11-04
- springboot下使用shiro自定义filter的个人经验分享 2024-02-27
- JavaWeb 实现验证码功能(demo) 2024-04-14
- Java编写实现窗体程序显示日历 2023-01-02
- 使用Java和WebSocket实现网页聊天室实例代码 2024-02-25
- JSP 动态树的实现 2023-12-17
- 深入理解约瑟夫环的数学优化方法 2024-03-07
