亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

delete 外鍵屬性報錯

老師您好 ? 當一個數據庫中有兩個表 (例如 student表 ?和course表 ?通過學號連接 ?在course表中sno是外鍵) ? 當我依據student表中的sno屬性刪除該學生的時候會 ?報出 不允許刪除父表(student)的sno屬性的 ?錯誤! ? ??

請問:

?1、怎么回事? ??

?2、該怎么解決呢??

正在回答

3 回答

當刪除父節點時,由數據庫來幫助刪除子節點,這樣就不用我們顯示地寫代碼先刪子節點,再刪父節點了。
第一步:刪除原有的外鍵約束

ALTER TABLE child_table DROP FOREIGN KEY `FK_Reference_2` ;

第二步:添加新的外鍵約束,增加ON DELETE CASCADE
ALTER TABLE child_table?
? ADD CONSTRAINT `FK_Reference_2`
? FOREIGN KEY (`parent_id` )
? REFERENCES parent_table (`parent_id` )
? ON DELETE CASCADE
? ON UPDATE RESTRICT;

這樣,就可以達到刪除父節點的時候,自動刪除子節點的目的了。


0 回復 有任何疑惑可以回復我~

當刪除有外鍵的屬性的數據時,需要先把該外鍵值關聯的數據刪除掉。這是外鍵約束的要求。

也就是說刪除student表的數據時,必須先把courcse表中通過sno關聯的數據刪除掉。

1 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

delete 外鍵屬性報錯

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號