[英]cascade delete in android room database KOTLIN
StackOverflow 中有很多這樣的問題,但大部分都不是關於房間數據庫的,所以我不得不問一個新問題。
我有一個使用房間數據庫的應用程序,它有近 4 個表並且這些表之間的關系很大,所以例如當我在用戶列表片段中刪除一個用戶時,該用戶刪除(只有用戶名和一些個人信息)但用戶的 TRANSACTIONS並且LOANS沒有被刪除。 有人告訴我我必須使用Cascade delete ,但我沒有找到太多關於它的信息。
我的用戶 class model:
@Entity(tableName = "user_info")
data class UserInfo(
@PrimaryKey(autoGenerate = true)
@ColumnInfo(name = "user_id")
var userId: Long =0L,
@ColumnInfo(name = "full_name")
var fullName:String?,
@ColumnInfo(name= "account_id")
var accountId: String?,
@ColumnInfo(name = "mobile_number")
var mobileNumber:String?,
@ColumnInfo(name = "phone_number")
var phoneNumber:String?,
@ColumnInfo(name = "date_of_creation")
var dateOfCreation:String?,
@ColumnInfo(name = "address")
var address:String?,
)
事務 model class:
@Entity(tableName = "transactions")
data class Transactions(
@PrimaryKey(autoGenerate = true)
@ColumnInfo(name = "trans_id")
var transId: Long = 0L,
@ColumnInfo(name = "user_id")
var userId: Long?,
@ColumnInfo(name = "create_date")
var createDate: String?,
@ColumnInfo(name = "bank_id")
var bankId: Long?,
@ColumnInfo(name = "description")
var description: String?,
@ColumnInfo(name = "increase")
var increase: String?,
@ColumnInfo(name = "decrease")
var decrease: String?,
@ColumnInfo(name = "loan_number")
var loanNumber: String?,
@ColumnInfo(name = "total")
var total: Long?,
@ColumnInfo(name = "type")
var type: String?
)
用戶 DAO:
@Insert
suspend fun insert(ui: UserInfo): Long
@Update
suspend fun update(ui: UserInfo)
@Insert
suspend fun insertList(ui: MutableList<UserInfo>)
@Delete
suspend fun deleteUser(ui: UserInfo)
@Query("DELETE FROM user_info")
fun deleteAllUser()
@Query("SELECT user_info.user_id, user_info.full_name, transactions.total From user_info JOIN transactions ")
fun joinTable(): LiveData<List<UserAndMoney>>?
@Query("SELECT * from user_info WHERE user_id = :key")
fun get(key: Long): LiveData<UserInfo>?
@Query("SELECT * FROM user_info ORDER BY full_name DESC")
fun getAllUserInfo(): LiveData<List<UserInfo>>
@Query("SELECT * FROM user_info where full_name like '%' || :fullName || '%' ORDER BY full_name ASC")
fun searchUserName(fullName: String): LiveData<List<UserInfo>>
如果到目前為止您還不清楚,讓我為您簡單介紹一下:
我需要級聯刪除來刪除有關用戶和記錄的所有內容。
CASCADE 是外鍵約束的一個選項。 所以你需要定義外鍵約束。 您可以通過 @Entity 注釋在 Room 中定義外鍵約束。
例如,看起來事務通過var userId: Long?,
(column name user_id) 與 UserInfo 相關,您可以:-
@Entity(tableName = "transactions",
foreignKeys = [
ForeignKey(
entity = UserInfo::class,
parentColumns = ["user_id"],
childColumns = ["user_id"],
onDelete = ForeignKey.CASCADE, //<<<<<
onUpdate = ForeignKey.CASCADE // Optional
)
]
)
data class Transactions(
@PrimaryKey(autoGenerate = true)
@ColumnInfo(name = "trans_id")
var transId: Long = 0L,
@ColumnInfo(name = "user_id", index = true) // <<<<< best to have an index on the column, not required
var userId: Long?,
@ColumnInfo(name = "create_date")
var createDate: String?,
@ColumnInfo(name = "bank_id")
var bankId: Long?,
@ColumnInfo(name = "description")
var description: String?,
@ColumnInfo(name = "increase")
var increase: String?,
@ColumnInfo(name = "decrease")
var decrease: String?,
@ColumnInfo(name = "loan_number")
var loanNumber: String?,
@ColumnInfo(name = "total")
var total: Long?,
@ColumnInfo(name = "type")
var type: String?
)
筆記
約束強制引用完整性,即如果 user_id 值不是 user_info 表的 user_id 列中存在的值,則無法插入/更新事務。
CASCADE onUpdate 將對 user_info 表中的 user_id 值的更改級聯到相應的事務。
有人告訴我我必須使用 Cascade delete,但我沒有找到太多關於它的信息。
您可以在沒有 CASCADE 的情況下復制該功能。
簡而言之,您可以使用
@Query("DELETE FROM transaction WHERE user_id=:userId")
fun cascadeDeletionsFromUser(userId: Long)
cascadeDeletionsFromUser
操作,則必須在刪除 user_info 行之前運行 cascadeDeletionsFromUser function。 否則無法刪除 user_info 行,因為 FK 約束會禁止刪除。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.