ホームページ >データベース >mysql チュートリアル >「エラー コード: 1062。重複エントリ エラー: 「ID」列の問題の解決\」が表示されるのはなぜですか?
エラー コード: 1062。重複エントリ エラー: "ID" 列の問題の解決
エラー コード: 1062 が発生しました。 「キー 'PRIMARY' のエントリ '1' が重複しています」は、主キー内の値が競合していることを示します。テーブルを詳しく調べて、この問題の根本原因を特定してみましょう。
UFICIO-INFORMAZIONI テーブル
提供されたテーブルは、UFFICIO-INFORMAZIONI テーブルの列の概要を示しています。 「ID」、「viale」、およびその他の属性が含まれます。 「ID」列は主キーとして指定されており、その値が行ごとに一意である必要があることを示しています。
重複エントリ エラーの原因
エラーこれは、「ID」列が重複したエントリで定義されているために発生します。指定した SQL ステートメント内:
<code class="sql">INSERT INTO `PROGETTO`.`UFFICIO-INFORMAZIONI` (`ID`, `viale`, `num_civico`, ...) VALUES (1, 'Viale Cogel ', '120', ...)</code>
「ID」列は明示的に「1」に設定されており、主キー制約と矛盾しています。主キーは一意である必要があるため、データベースはエラーを生成します。
解決策: AUTO_INCREMENT の使用
この問題を解決するには、「ID」列を AUTO_INCREMENT として設定することを検討してください。 。これにより、データベースは挿入操作中に「ID」列の一意の値を自動的に生成し、主キーの整合性を確保します。
AUTO_INCREMENT を使用して変更したテーブル定義は次のとおりです。
<code class="sql">CREATE TABLE IF NOT EXISTS `PROGETTO`.`UFFICIO-INFORMAZIONI` ( `ID` INT(11) NOT NULL AUTO_INCREMENT, `viale` VARCHAR(45) NULL , .....</code>
'ID' を指定せずにレコードを挿入する
AUTO_INCREMENT を有効にしてレコードを挿入する場合、SQL ステートメントでの 'ID' 列の指定を省略できます。データベースは各行に一意の ID を自動的に割り当てます。
例:
<code class="sql">INSERT INTO `PROGETTO`.`UFFICIO-INFORMAZIONI` (`viale`, `num_civico`, ...) VALUES ('Viale Cogel ', '120', ...)</code>
重複エントリの問題に対処し、AUTO_INCREMENT を実装することで、UFFICIO へのレコードのスムーズな挿入を保証できます。 -情報テーブル
以上が「エラー コード: 1062。重複エントリ エラー: 「ID」列の問題の解決\」が表示されるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。