Jul*_*les 7 java foreign-keys ormlite
我正在尝试创建一个对象,并在一个操作中填充该对象持有的外部集合的成员.我已经尝试了我能想到的每一个操作顺序,而且似乎无法让它工作.
我的课程是(跳过不相关的字段和注释):
@DatabaseTable
public class ScheduledJob
{
@DatabaseField(id=true)
private String id = UUID.randomUUID ().toString ();
@ForeignCollectionField(eager=true)
private Collection<ScheduledJobTask> tasks;
/* other stuff here ... */
}
@DatabaseTable
public class ScheduledJobTask
{
@DatabaseField(id=true)
private String id = UUID.randomUUID ().toString ();
@DatabaseField(foreign=true)
private ScheduledJob job;
/* more other stuff ... */
public ScheduledJobTask(Task t) {
/* initialise scheduled task from template task by copying relevant fields...*/
}
}
Run Code Online (Sandbox Code Playgroud)
我这样创建我的对象:
ScheduledJob job = new ScheduledJob ();
// fill in other fields of job here
job.tasks = new ArrayList<ScheduledJobTask> ();
for (Task t : template.getTasks())
job.tasks.add(new ScheduledJobTask(t));
sched.getSchedule().add (job); // 'sched' is an object loaded from another table, this
// adds 'job' to a foreign collection in that table
Storage.store.scheduledJobs.createIfNotExists (job);
for (ScheduledJobTask t : job.getTasks ())
Storage.store.scheduledJobTasks.createIfNotExists (t);
Storage.store.daySchedules.update (sched);
Run Code Online (Sandbox Code Playgroud)
我已经尝试了最后三个语句的所有排序,但似乎没有任何作用:在每种情况下,最终在scheduledjobtask数据库表中的条目的'job_id'字段都为null.
我做错了什么想法?
您缺少的是您没有设置该Task.job字段。该ScheduledJobTask.job字段是建立外国集合的内容。当你检索一个Job,它会在任务表中查找具有该作业的所有任务,而不是相反。
您将需要执行以下操作:
for (Task t : template.getTasks()) {
t.setJob(job);
job.tasks.add(new ScheduledJobTask(t));
}
Run Code Online (Sandbox Code Playgroud)
然后,当你这样做时:
Storage.store.scheduledJobs.createIfNotExists (job);
Run Code Online (Sandbox Code Playgroud)
所有字段job都会有一个Job具有id字段集的 。因此,当您保留任务时,他们的工作字段将具有该工作 ID。
| 归档时间: |
|
| 查看次数: |
5307 次 |
| 最近记录: |