1

私は現在、1452エラーで頭を悩ませています(Symfony2を教義で使用しています)。

ケースは次のとおりです。ロケーション、コンサート、CDの3つのテーブルがあり、予想どおり、コンサートはロケーションで行われ、CDはコンサートに関連しており、いくつかの外部キーが含まれています。

データベースを作成するためにdoctrineによって生成されたSQLクエリは次のとおりです。

CREATE TABLE CD (id INT AUTO_INCREMENT NOT NULL, concert INT NOT NULL, number INT NOT NULL, INDEX IDX_EB3C8BB0D57C02D2 (concert), PRIMARY KEY(id)) ENGINE = InnoDB;
CREATE TABLE Concert (id INT AUTO_INCREMENT NOT NULL, location INT NOT NULL, date DATETIME NOT NULL, name VARCHAR(255) DEFAULT NULL, INDEX IDX_1AC13B4E5E9E89CB (location), PRIMARY KEY(id)) ENGINE = InnoDB;
CREATE TABLE Location (id INT AUTO_INCREMENT NOT NULL, name VARCHAR(40) NOT NULL, city VARCHAR(40) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB;
ALTER TABLE CD ADD CONSTRAINT FK_EB3C8BB0D57C02D2 FOREIGN KEY (concert) REFERENCES Concert(id) ON UPDATE CASCADE ON DELETE CASCADE;
ALTER TABLE Concert ADD CONSTRAINT FK_1AC13B4E5E9E89CB FOREIGN KEY (location) REFERENCES Location(id) ON UPDATE CASCADE ON DELETE CASCADE;

実際には、CDの外部キーを満たすために、ロケーションと接続されたコンサートを挿入するのに問題はありません。

INSERT INTO Location (id, name, city) VALUES (NULL, 'Church', 'Berlin');
INSERT INTO Concert (id, location, date, name) VALUES (NULL, '1', '2012-06-20 19:30:00', NULL);

しかし、CDを挿入しようとすると、次のようになります。

INSERT INTO  CD (id ,concert ,number) VALUES (NULL ,  '1',  '1');

有名なエラーが発生しました:

Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`festival`.`cd`, CONSTRAINT `FK_EB3C8BB0D57C02D2` FOREIGN KEY (`concert`) REFERENCES `Concert` (`id`) ON DELETE CASCADE ON UPDATE CASCADE)

だから私はいくつかのハックを試しました:

  1. テーブルLocationと関連するキーの作成をエスケープします。

    CREATE TABLE CD (id INT AUTO_INCREMENT NOT NULL, concert INT NOT NULL, number INT NOT NULL, INDEX IDX_EB3C8BB0D57C02D2 (concert), PRIMARY KEY(id)) ENGINE = InnoDB;
    CREATE TABLE Concert (id INT AUTO_INCREMENT NOT NULL, location INT NOT NULL, date DATETIME NOT NULL, name VARCHAR(255) DEFAULT NULL, INDEX IDX_1AC13B4E5E9E89CB (location), PRIMARY KEY(id)) ENGINE = InnoDB;
    ALTER TABLE CD ADD CONSTRAINT FK_EB3C8BB0D57C02D2 FOREIGN KEY (concert) REFERENCES Concert(id) ON UPDATE CASCADE ON DELETE CASCADE;
    

    それはうまく機能しています。

  2. 作成後にテーブルの場所(および関連するキー)を削除します。

    CREATE TABLE CD (id INT AUTO_INCREMENT NOT NULL, concert INT NOT NULL, number INT NOT NULL, INDEX IDX_EB3C8BB0D57C02D2 (concert), PRIMARY KEY(id)) ENGINE = InnoDB;
    CREATE TABLE Concert (id INT AUTO_INCREMENT NOT NULL, location INT NOT NULL, date DATETIME NOT NULL, name VARCHAR(255) DEFAULT NULL, INDEX IDX_1AC13B4E5E9E89CB (location), PRIMARY KEY(id)) ENGINE = InnoDB;
    CREATE TABLE Location (id INT AUTO_INCREMENT NOT NULL, name VARCHAR(40) NOT NULL, city VARCHAR(40) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB;
    ALTER TABLE CD ADD CONSTRAINT FK_EB3C8BB0D57C02D2 FOREIGN KEY (concert) REFERENCES Concert(id) ON UPDATE CASCADE ON DELETE CASCADE;
    ALTER TABLE Concert ADD CONSTRAINT FK_1AC13B4E5E9E89CB FOREIGN KEY (location) REFERENCES Location(id) ON UPDATE CASCADE ON DELETE CASCADE;
    ALTER TABLE Concert DROP FOREIGN KEY FK_1AC13B4E5E9E89CB;
    ALTER TABLE Concert DROP INDEX IDX_1AC13B4E5E9E89CB;
    DROP TABLE Location;
    

    同じエラー。

  3. 外部キー制御をエスケープする

    SET FOREIGN_KEY_CHECKS = 0;
    

    同じエラー。

最後の2つの試みは、コンサート-場所のリンクにあるインデックスの問題について考えさせてください。ご存知のとおり、私は少し迷っています。

誰かがすでに似たようなことに直面していますか?

知識をありがとう、

トム。

4

1 に答える 1

0

そう、

MySQL のドキュメントによると、OSX 上の 5.5.9 以降の MySQL サーバーは、外部キーの挿入に失敗します。このバグには大文字と小文字の区別があるようです。

これを修正するには多くの方法があります (このリストは網羅的なものではなく、一部のオプションは効果的でない場合があります)。

  • 小文字のテーブル名のみを使用してください。
  • lower_case_table_namesを O または 1に設定してみてください(ただし、OS X では、システムの大文字と小文字の区別が原因であるとは限りません)。
  • MySQL サーバー 5.5.8 にダウングレードします (アップグレードはテストしていません)。

このスレッドのおかげです

于 2012-06-19T14:40:48.003 に答える