AndroidRoom:关联多个子表
创始人
2024-10-09 19:31:30
0

假设我们有三个数据表:学校、班级和学生。每个学校可以有多个班级,每个班级可以有多个学生。现在我们想要使用Android Room查询每个学校及其所包含的班级和学生。

首先,我们需要定义三个实体类:School、Class和Student。 School实体类应该包含主键和其他属性,而Class和Student实体类应该包含外键以引用School表中的主键。

@Entity(tableName = "school")
data class School(
    @PrimaryKey
    @ColumnInfo(name = "id") val id: Int,
    @ColumnInfo(name = "name") val name: String
)

@Entity(tableName = "class", foreignKeys = [
    ForeignKey(entity = School::class, parentColumns = ["id"], childColumns = ["school_id"])
])
data class Class(
    @PrimaryKey
    @ColumnInfo(name = "id") val id: Int,
    @ColumnInfo(name = "name") val name: String,
    @ColumnInfo(name = "school_id") val schoolId: Int
)

@Entity(tableName = "student", foreignKeys = [
    ForeignKey(entity = Class::class, parentColumns = ["id"], childColumns = ["class_id"])
])
data class Student(
    @PrimaryKey
    @ColumnInfo(name = "id") val id: Int,
    @ColumnInfo(name = "name") val name: String,
    @ColumnInfo(name = "class_id") val classId: Int
)

然后,我们需要创建一个包含所有三个实体类的数据访问对象(DAO)。我们可以使用@Transaction注释和自定义查询来获取与每个学校、其关联的班级和每个班级、其关联的学生相关的所有数据。

@Dao
interface SchoolDao {
    @Query("SELECT * FROM school")
    fun getSchoolsWithClassesAndStudents(): List

    @Transaction
    @Query("SELECT * FROM school")
    fun getSchoolsWithClassesAndStudentsLiveData(): LiveData>
}

我们还需要定义一个包含School、Class和Student实体的数据类SchoolWithClassesAndStudents,以便我们可以一次性获取所有请求的数据。

data class SchoolWithClassesAndStudents(
    @Embedded val school: School,
    @Relation(
        parentColumn = "id",
        entityColumn = "school_id"
    )
    val classes: List
)

data class ClassWithStudents(
    @Embedded val class: Class,

相关内容

热门资讯

解迷透视!红龙poker辅助工... 解迷透视!红龙poker辅助工具!切实是有辅助教程(有挂教程)-哔哩哔哩1、红龙poker辅助工具辅...
详情透视!pokemmo辅助官... 详情透视!pokemmo辅助官网!其实有辅助软件(发现有挂)-哔哩哔哩1、玩家可以在pokemmo辅...
必备透视!wepoker透视有... 必备透视!wepoker透视有吗!竟然有辅助教程(真是有挂)-哔哩哔哩1、点击下载安装,wepoke...
解谜透视!红龙poker辅助工... 解谜透视!红龙poker辅助工具!其实真的是有辅助插件(有挂秘笈)-哔哩哔哩1、下载好红龙poker...
必备透视!pokemmo辅助脚... 必备透视!pokemmo辅助脚本!都是是真的有辅助神器(存在有挂)-哔哩哔哩所有人都在同一条线上,像...
教你透视!pokemmo辅助器... 教你透视!pokemmo辅助器!真是是真的有辅助app(有挂技术)-哔哩哔哩1、完成pokemmo辅...
专业透视!德州透视是真的假的!... 专业透视!德州透视是真的假的!一直存在有辅助工具(有挂秘笈)-哔哩哔哩1、德州透视是真的假的破解器简...
解迷透视!德州局脚本!竟然一直... 解迷透视!德州局脚本!竟然一直都是有辅助方法(有挂教程)-哔哩哔哩1、打开软件启动之后找到中间准星的...
分享透视!聚星ai辅助工具下载... 分享透视!聚星ai辅助工具下载!原来有辅助神器(有挂秘笈)-哔哩哔哩1、超多福利:超高返利,海量正版...
科普透视!werplan外开挂... 科普透视!werplan外开挂!总是真的有辅助技巧(有挂方略)-哔哩哔哩1、下载好werplan外开...