为了在 Android Room 中实现一对多关系,需要首先定义实体类和它们之间的关联,然后在数据库中创建相应的表格。以下是一个简单的示例,假设有一对一篇文章有多个评论的关系:
@Entity(tableName = "article") public class Article { @PrimaryKey public int id;
public String title;
public String content;
}
@Entity(tableName = "comment", foreignKeys = @ForeignKey(entity = Article.class, parentColumns = "id", childColumns = "article_id", onDelete = CASCADE)) public class Comment { @PrimaryKey public int id;
public int article_id;
public String text;
}
在这个示例中,Article 类表示一篇文章,具有 id、title 和 content 属性。Comment 类表示一条评论,具有 id、article_id 和 text 属性。请注意,Comment 类包含一个名为 article_id 的属性,它将评论与所属的文章联系起来。
为了在数据库中创建这两个表格并定义它们之间的关系,需要定义一个抽象类,它扩展了 RoomDatabase、并创建它们的 DAO 对象。以下是一个示例:
@Database(entities = {Article.class, Comment.class}, version = 1, exportSchema = false) public abstract class AppDatabase extends RoomDatabase { public abstract ArticleDao articleDao(); public abstract CommentDao commentDao(); }
在此示例中,AppDatabase 类扩展了 RoomDatabase 并将 Article 和 Comment 实体指定为其数据库表。它还定义了 ArticleDao 和 CommentDao 的抽象方法,它们将分别用于访问 Article 和 Comment 表格。
现在,为了在应用中使用这些 DAO 对象,需要在您的应用代码中使用 RoomDatabase.Builder 创建一个 AppDatabase 实例。以下是一个示例:
AppDatabase db = Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "app_database").build();
现在,您可以使用 articleDao() 和 commentDao() 方法来访问文章和评论表中的数据。例如,要检索所有文章及其相应的评论,可以使用以下代码:
List
在此示例中,getArticlesWithComments() 方法在 ArticleDao 中定义,并使用 @Relation 注释表示它返回 ArticleWithComments 类型的列表。ArticleWithComments 类表示一篇文章及其相关评论,它包含一个 Article 对象