使用Room Persistence库插入一对多关系

时间:2018-07-06 11:42:25

标签: android android-sqlite android-room android-architecture-components android-jetpack

我遇到一种情况,我想使用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注释)。

1 个答案:

答案 0 :(得分:1)

我已通过@Transaction注解解决了这个问题。

 @Transaction
fun insertStoreWithPictures(store: Store, pictures: List<StorePicture>) {

    insertStore(store)
    insertPictures(pictures)

}
  

使用@Transaction注释方法可确保所有数据库   您在该方法中执行的操作将在一个方法中运行   交易。引发异常时,事务将失败   方法主体。