我有 2 個實體:1. 用戶2. 限制用戶有一組限制,因此存在一對多關系。我確實將級聯類型設置為delete,因此當User刪除 時,也應刪除所有相應的限制。<bag name="limits" cascade="delete"> <key column="USER_ID"/> <one-to-many class="com.mac.kom.modules.limits.models.LimitsModel" /></bag>當我嘗試刪除時,User我收到錯誤Caused by: java.sql.SQLException: ORA-01407: cannot update ("DB"."LIMITS"."USER_ID") to NULL有什么線索嗎?
2 回答

不負相思意
TA貢獻1777條經驗 獲得超10個贊
你應該級聯delete-orphan
。delete
嘗試通過清除 FK 字段來斷開兩個實體之間的鏈接。delete-orphan
不會授權有一些LimitsModel
沒有User
,因此會刪除相關LimitsModel
記錄。

紫衣仙女
TA貢獻1839條經驗 獲得超15個贊
嘗試這個
<bag name="limits">
<key column="USER_ID" on-delete="cascade"/>
<one-to-many class="com.mac.kom.modules.limits.models.LimitsModel" />
</bag>
添加回答
舉報
0/150
提交
取消