MySQL エラー 1215: 外部キー制約を追加できません 質問する

MySQL エラー 1215: 外部キー制約を追加できません 質問する

新しいスキーマをデータベース サーバーにフォワード エンジニアリングしようとしていますが、このエラーが発生する理由がわかりません。

ここで答えを探してみましたが、見つけたものはすべて、データベース エンジンを InnoDB に設定するか、外部キーとして使用しようとしているキーが独自のテーブルの主キーであることを確認するようにと書いてありました。間違っていなければ、この 2 つの操作は両方とも実行しました。他に何ができるでしょうか。

Executing SQL script in server

ERROR: Error 1215: Cannot add foreign key constraint

-- -----------------------------------------------------
-- Table `Alternative_Pathways`.`Clients_has_Staff`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `Alternative_Pathways`.`Clients_has_Staff` (
  `Clients_Case_Number` INT NOT NULL ,
  `Staff_Emp_ID` INT NOT NULL ,
  PRIMARY KEY (`Clients_Case_Number`, `Staff_Emp_ID`) ,
  INDEX `fk_Clients_has_Staff_Staff1_idx` (`Staff_Emp_ID` ASC) ,
  INDEX `fk_Clients_has_Staff_Clients_idx` (`Clients_Case_Number` ASC) ,
  CONSTRAINT `fk_Clients_has_Staff_Clients`
    FOREIGN KEY (`Clients_Case_Number` )
    REFERENCES `Alternative_Pathways`.`Clients` (`Case_Number` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_Clients_has_Staff_Staff1`
    FOREIGN KEY (`Staff_Emp_ID` )
    REFERENCES `Alternative_Pathways`.`Staff` (`Emp_ID` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB

SQL スクリプトの実行が終了しました: ステートメント: 7 個が成功、1 個が失敗

親テーブルの SQL は次のとおりです。

CREATE  TABLE IF NOT EXISTS `Alternative_Pathways`.`Clients` (
  `Case_Number` INT NOT NULL ,
  `First_Name` CHAR(10) NULL ,
  `Middle_Name` CHAR(10) NULL ,
  `Last_Name` CHAR(10) NULL ,
  `Address` CHAR(50) NULL ,
  `Phone_Number` INT(10) NULL ,
  PRIMARY KEY (`Case_Number`) )
ENGINE = InnoDB

CREATE  TABLE IF NOT EXISTS `Alternative_Pathways`.`Staff` (
  `Emp_ID` INT NOT NULL ,
  `First_Name` CHAR(10) NULL ,
  `Middle_Name` CHAR(10) NULL ,
  `Last_Name` CHAR(10) NULL ,
  PRIMARY KEY (`Emp_ID`) )
ENGINE = InnoDB

ベストアンサー1

Clients.Case_Numberおよび/または は およびとStaff.Emp_IDまったく同じデータ型ではないと推測します。Clients_has_Staff.Clients_Case_NumberClients_has_Staff.Staff_Emp_ID

おそらく親テーブルの列は でしょうかINT UNSIGNED?

両方のテーブルでデータ型がまったく同じである必要があります。

おすすめ記事