嘗試使用MySQL 建立表時,遇到錯誤1022:“無法寫入;重複鍵在表中。”特殊之處在於該表僅定義了一個鍵,但錯誤仍然存在。
經調查,似乎是表定義中的特定片段觸發了錯誤:
CONSTRAINT `error_id`
FOREIGN KEY (`error_id` )
REFERENCES `mydb`.`errors` (`error_id` )
ON DELETE NO ACTION
ON UPDATE NO ACTION,
雖然其他表中存在類似的外鍵定義,沒有問題,但問題在於外鍵的名稱:error_id.
根本原因:
出現此問題的原因是外鍵名稱不能與整個資料庫模型中的另一個外鍵名稱相同。這意味著如果兩個表引用同一個表,則每個表中的外鍵必須具有唯一的名稱。
解決方案:
要解決該錯誤,只需給出有問題的外鍵有不同的名稱。例如,您可以將其命名為 fk_error_id。這會將其與模型中的任何其他外鍵區分開來,並允許 MySQL 成功建立表。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3