AndroidJetpackRoom一对多查询Where
创始人
2024-10-08 12:02:05
0
  1. 首先,在 Room 数据库中定义两个实体类 Parent 和 Child,它们之间是一对多关系,即一个 Parent 对象可以拥有多个 Child 对象。

@Entity class Parent { @PrimaryKey var id: Int = 0 var name: String = "" }

@Entity(foreignKeys = [ForeignKey(entity = Parent::class, parentColumns = ["id"], childColumns = ["parentId"])]) class Child { @PrimaryKey var id: Int = 0 var parentId: Int = 0 var name: String = "" }

  1. 创建一个 DAO 接口 ParentDao,用于查询 Parent 和对应的多个 Child。

@Dao interface ParentDao { // 查询一个 Parent 包含的所有 Child,并限制 Child 的 name 属性为指定值 @Transaction @Query("SELECT * FROM Parent WHERE id = :parentId") fun getParentWithChildren(parentId: Int): ParentWithChildren }

// 定义一个数据类 ParentWithChildren,用于存储查询结果 data class ParentWithChildren( @Embedded val parent: Parent, @Relation(parentColumn = "id", entityColumn = "parentId") val children: List )

  1. 在查询中使用 WHERE 语句限制 Child 的 name 属性。

val parentWithChildren = parentDao.getParentWithChildren(parentId) val matchedChildren = parentWithChildren.children.filter { it.name == "指定值" }

相关内容

热门资讯

透视教学"wepok... 透视教学"wepoker私人局怎么玩"hhpoker视频巡查真的假的(其实是真的辅助插件)-哔哩哔哩...
透视揭幕"hhpok... 透视揭幕"hhpoker一直输有挂吗"果然真的是有辅助技巧(哔哩哔哩);1、用户打开应用后不用登录就...
透视计算"wepok... 透视计算"wepoker有辅助器吗"aapoker透视方法(总是存在有辅助修改器)-哔哩哔哩1、we...
透视透视"wepok... 透视透视"wepoker分析"总是真的是有辅助插件(哔哩哔哩)1、游戏颠覆性的策略玩法,独创攻略技巧...
据报道"wepoke... 据报道"wepoker线上大神"hhpoker为什么一直输(真是是真的辅助下载)-哔哩哔哩1、hhp...
透视教你"wepok... 透视教你"wepoker透视脚本是什么"果然有辅助技巧(哔哩哔哩)wepoker透视脚本是什么脚本下...
据统计"hhpoke... 据统计"hhpoker有透视功能吗"cloudpoker外开挂(果然存在有辅助app)-哔哩哔哩1、...
透视美元局"wpk安... 透视美元局"wpk安卓下载辅助"hhpoker一直输有挂吗(都是真的有辅助工具)-哔哩哔哩1、全新机...
透视总结"werpl... 透视总结"werplan外开挂"本来真的是有辅助教程(哔哩哔哩)1、werplan外开挂免费脚本咨询...
围绕透视问题"红龙p... 围绕透视问题"红龙poker辅助"购买的wpk辅助在哪里下载(都是是真的辅助平台)-哔哩哔哩1、进入...