簡體   English   中英

Grails GORM和MYSQL級聯刪除問題

[英]Grails GORM and MYSQL cascade delete problem

我有一個表用戶在靜態hasMany grails下的User類中定義了許多子表。

在grails中執行User.get(3).delete()時沒有問題。 它會自動刪除該用戶及其所有子表行。 但是當我想在MySQL工作台中執行相同的操作時。 我得到MySQL拋出的錯誤:

ERROR 1451: Cannot delete or update a parent row: a foreign key constraint fails (`test_db`.`search_stat`, CONSTRAINT `FK7A3CFFB6E64DB41` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`))
SQL Statement:
DELETE FROM `test_db`.`user` WHERE `id`='3'

我不知道MySQL有什么問題。

您在哪里閱讀了文檔中的“ON DELETE CASCADE”? 在這里找不到它。 這篇文章的海報必須手動添加它以獲得所需的行為。

如果grails真的應該添加它,你是否嘗試刪除數據庫並讓它由grails重新創建(至少在開發環境中)? 也許在添加belongsTo之前生成了當前架構?

另請查看關於GORM Gotchas的關於hasMany和belongsTo的博客文章。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM