Cascade delete based on @ForeignKey in Android Rooms ORM


Cascade delete based on @ForeignKey in Android Rooms ORM



I have two entities DBList adnd DBListContent. With one to many relationship between DBList and DBListContent.


DBList


DBListContent


DBList


DBListContent



Here is the DBList class


DBList


@Entity(tableName = "lists")
public class DBList {
@PrimaryKey
private String listId;
private String title;
private String createdDateTime;
}



Here is the DBListContent


DBListContent


@Entity(tableName = "listContents")
public class DBListContent {
@PrimaryKey
public String listContentId;
public String content;
public String lastEditedBy;
public String lastEditedDateTime;

@ForeignKey(entity = DBList.class, parentColumns = "listId", childColumns = "dbListId", onDelete = CASCADE)
public String dbListId;
}



When I delete a row in lists table, the corresponding rows in the listContents table are not deleted.


lists


listContents



I deleted the rows using the following Dao methods


@Delete
void deleteLists(List<DBList> dbLists);

@Query("delete from lists")
void deleteLists();



I know I am missing something pretty obvious. Please guide me in this.




1 Answer
1



I don't know it's too late to answer your question, but the mistake you have is to put @ForeignKey in a field.


@ForeignKey



The @ForeignKeys MUST to go in table declaration.


@ForeignKeys



Your code should look like that.


@Entity(tableName = "listContents",foreignKeys ={
@ForeignKey(onDelete = CASCADE,entity = DBList.class,
parentColumns = "listId",childColumns = "dbListId")},
indices = {
@Index("dbListId"),
})
public class DBListContent {
@PrimaryKey
public String listContentId;
public String content;
public String lastEditedBy;
public String lastEditedDateTime;
public String dbListId;
}






By clicking "Post Your Answer", you acknowledge that you have read our updated terms of service, privacy policy and cookie policy, and that your continued use of the website is subject to these policies.

Popular posts from this blog

PySpark - SparkContext: Error initializing SparkContext File does not exist

django NoReverseMatch Exception

List of Kim Possible characters