嘗試使用MySQL 建立表格時,遇到錯誤1022:「無法寫入;重複鍵在表中。」奇怪的是,該表只定義了一個鍵,但錯誤仍然存在。
經調查,似乎表定義中的特定片段觸發了錯誤:
<code class="sql">CONSTRAINT `error_id` FOREIGN KEY (`error_id` ) REFERENCES `mydb`.`errors` (`error_id` ) ON DELETE NO ACTION ON UPDATE NO ACTION,</code>
雖然類似的外鍵定義存在於其他表中沒有問題,但問題在於外鍵名稱:error_id。
根本原因:
出現此問題的原因是外鍵名稱不能與整個資料庫模型中的另一個外鍵名稱相同。這意味著如果兩個表引用同一個表,則每個表中的外鍵必須具有唯一的名稱。
解:
要解決這個錯誤,只需給出有問題的外鍵有不同的名稱。例如,您可以將其命名為 fk_error_id。這會將其與模型中的任何其他外鍵區分開來,並允許 MySQL 成功建立表。
以上是為什麼我會收到 MySQL 錯誤 1022:「無法寫入;表中有重複的鍵。」即使我只有一個鍵?的詳細內容。更多資訊請關注PHP中文網其他相關文章!