gpt4 book ai didi

android - 房间持久性在更新时删除子项

转载 作者:太空宇宙 更新时间:2023-11-03 10:59:24 24 4
gpt4 key购买 nike

我正在使用 Room Library 将数据保存在我的 Android 应用程序中。我有 2 个主表,分别是任务和组。这种关系是一对多的,一个任务只能属于一个组,但是一个组可以属于多个任务。

持久性工作正常,但问题是当我尝试更新组中的信息时,与该组相关的每个任务都被删除。

下面是我的实体和 DAO 配置:

任务实体

@Entity(tableName = "task",
foreignKeys = {
@ForeignKey(
entity = Group.class,
parentColumns = "id",
childColumns = "groupId",
onDelete = CASCADE,
onUpdate = RESTRICT
)},
indices = {@Index(value = "id"), @Index(value = "groupId")}
)
public class Task {

@PrimaryKey(autoGenerate = true)
private int id;
private String name;
private int groupId;

public Task(int id, String name, int groupId) {
this.id = id;
this.name = name;
this.groupId = groupId;
}

}

集团实体

 @Entity(tableName = "group")
public class Group {

@PrimaryKey(autoGenerate = true)
private int id;
private String name;

public Group(int id, String name) {
this.id = id;
this.name = name;
}

}

任务DAO

@Dao
public interface TaskDao {

@Insert(onConflict = OnConflictStrategy.REPLACE)
void addTask(Task task);

@Query("select * from task")
public List<Task> listAllTasks();

@Query("select * from task where id = :taskId")
public Task getTask(int taskId);

@Update(onConflict = OnConflictStrategy.REPLACE)
void updateTask(Task task);

@Query("delete from task")
void removeAllTasks();

@Delete
void delete(Task task);
}

组DAO

@Dao
public interface GroupDao {

@Insert(onConflict = OnConflictStrategy.REPLACE)
void addGroup(Group group);

@Query("select * from `group`")
public List<Group> listAllGroups();

@Query("select * from `group` where id = :groupId")
public Group getGroup(long groupId);

@Update(onConflict = OnConflictStrategy.REPLACE)
void updateGroup(Group group);

@Query("delete from `group`")
void removeAllGroups();

@Delete
void delete(Group group);

}

在 Task 类的实体声明中将 OnUpdate 更改为 RESTRICT、CASCADE 或 NO_ACTION 没有帮助。

我将不胜感激任何帮助。谢谢。

最佳答案

As in SQLite Documentation:当发生 UNIQUE 或 PRIMARY KEY 约束违规时,REPLACE 算法会在插入或更新当前行之前删除导致约束违规的预先存在的行,并且命令会继续正常执行。如果发生 NOT NULL 约束违例,REPLACE 冲突解决方案将 NULL 值替换为该列的默认值,或者如果该列没有默认值,则使用 ABORT 算法。如果发生 CHECK 约束或外键约束违规,REPLACE 冲突解决算法将像 ABORT 一样工作。

当 REPLACE 冲突解决策略删除行以满足约束时,删除触发器将当且仅当启用递归触发器时触发

And as in google Documentations: 默认情况下,所有 RoomDatabase 都使用内存存储 TEMP 表并启用递归触发器。

结论:**由于您使用的是 REPLACE ConflictStrategy,并且外键 **CASCADE 删除父实体,因此当您尝试删除时,每个子行都会被删除插入父行已经存在。

解决方案:使用 @Query 像这样更新组

@Query("UPDATE groups SET columnToUpdate1 = :value1, columnToUpdate2 = :value2 WHERE id=:id")
void updateGroup(int id, value1,value2);

关于android - 房间持久性在更新时删除子项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47997017/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com