我遇到一种情况,我想使用Room Persistence Library以一对多关系在Master(store_master)和Mapping(store_mapping)表中插入数据。我的实现如下:
@Entity(tableName = "store_master")
class Store {
@PrimaryKey(autoGenerate = true)
public var store_id: Int = 0
@SerializedName("name")
lateinit var store_name: String
}
@Entity(tableName = "store_mapping", foreignKeys = arrayOf(
ForeignKey(entity = Store::class,
parentColumns = arrayOf("store_id"),
childColumns = arrayOf("pic_id"),
onDelete = CASCADE)))
class StorePicture(@field:PrimaryKey(autoGenerate = true)
@ColumnInfo(name = "id") var id: Int,
@SerializedName("pic_id") var pic_id: Int?,
@SerializedName("image") var storage_picture: String?)
class StoreWithPictures {
@Embedded
var store: Store? = null
@Relation(parentColumn = "store_id",
entityColumn = "pic_id")
var pictures: List<StorePicture> = ArrayList()
}
要获取带有图片的商店,我的实现如下:
@Transaction
@Query("SELECT * FROM store_master ORDER BY store_master.storage_id DESC")
fun loadAll(): List<StoreWithPictures>
上述方法可以很好地从主表和映射表中获取数据,但是我无法以相同的方式插入(即使用@Embeded和@transaction注释)。
答案 0 :(得分:1)
我已通过@Transaction
注解解决了这个问题。
@Transaction
fun insertStoreWithPictures(store: Store, pictures: List<StorePicture>) {
insertStore(store)
insertPictures(pictures)
}
使用@Transaction注释方法可确保所有数据库 您在该方法中执行的操作将在一个方法中运行 交易。引发异常时,事务将失败 方法主体。