Я пытаюсь сохранить ленивую ForeignCollection с помощью ormlite. 4.42 и sqlite в настольном приложении.
У меня есть класс Event
, который содержит коллекцию EventDate
:
@DatabaseTable(tableName = "event")
public class Event extends BaseDaoEnabled<Event, Integer> implements Scrap {
@DatabaseField(generatedId = true, columnName = "_id")
private int id;
@ForeignCollectionField(eager = true)
private ForeignCollection<EventDate> dates;
}
Класс EventDate
:
@DatabaseTable(tableName = "eventdate")
public class EventDate extends BaseDaoEnabled<EventDate, Integer> {
@DatabaseField(generatedId = true, columnName = "_id")
int id;
@DatabaseField(canBeNull = true, foreign = true)
Event event;
}
А вот код, который я использую, чтобы добавить EventDates
и сохранить их:
Event e2 = eventDao.queryForId(id));
e2.getDates().clear();
for (final EventDate date : dates) {
e2.getDates().add(date);
e2.getDates().update(date);
}
e2.update();
EvenDates
правильно добавлены в таблицу sqlite, но поле event_id
равно null: EventDates
не связаны с Event
.
У меня нет сообщения об ошибке. Что я делаю не так ?
Примечание. Я пробовал с нетерпеливой коллекцией (добавляя e2.getDates().updateAll()
), но это тоже не работает.