我有一个具有非常复杂数据类型的 Android java 项目,包括其他复杂数据类型的 ArrayLists。我正在尝试使用 ORMLite (4.42) 将我的数据存储在数据库中。
我在 ArrayLists 和 ForeignCollection 之间转换时遇到了重大问题,有人能做到这一点吗?
我不希望与数据库持续同步,而是有一个保存整个结构的 save 方法和一个恢复整个方法的 read 方法。从数据库中恢复对象后,该对象通过接口发送,接收者需要一个 ArrayLists 而不是 orm lite ForeignCollections。
我的方法如下。对于每个 ArrayList,我都有一个互补的 ForeignCollection。在将对象存储到数据库之前,将 ArrayList 的内容复制到 ForeignCollection,当读回时,反之亦然。
当我从数据库中读出一个数据结构时,我希望确保整个结构被恢复,因为稍后,该对象将被发送给不知道 orm lite 包的用户,因此我设置了 eager = true。
我的复杂数据类型如下所示:
@DatabaseTable(tableName = "accounts")
public class Account {
@DatabaseField(generatedId = true)
private int id;
@ForeignCollectionField (eager = true, maxEagerLevel = 2)
private ForeignCollection<Order> ordersFoC;
private ArrayList<Order> ordersArL;
问题
在将帐户存储到数据库之前,我尝试执行以下操作。我希望将 ArrayList 中的对象复制到 ForeignCollection 并使用 Account 对象更新数据库。对象 myAccount 与数据库中的对象具有相同的 id,因此我希望更新该对象。
ordersFoC.addAll(orderArL);
myDao.createOrUpdate(myAccount);
没运气。addAll 方法确实将订单直接写入数据库,因此我最终得到了所有订单的重复项,因为“addAll”添加并且不更新任何现有记录。
所以我尝试首先从数据库中删除所有订单,但再次没有运气:
ordersFoC.clear(); // Also tried: ordersFoC.removeAll(ordersFoC);
ordersFoC.addAll(orderArL);
myDao.createOrUpdate(myAccount);
对象不会从数据库中删除。我在groups.google.com 上读到(作者 Philip Fu),这是 ormlite 的一个“已知”问题,急切的 ForeignCollection 不能很好地与 removeAll() 或 clear() 配合使用。
是否有一种我错过的模式允许我使用 ormlite 框架处理包含复杂类型的 ArrayLists 的对象?