【问题标题】:#1005 - Can't create table 'feedback.answer' (errno: 150)#1005 - 无法创建表“feedback.answer”(错误号:150)
【发布时间】:2013-11-29 03:11:37
【问题描述】:

我在使用 mysql 时遇到错误,我不明白为什么:

SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL,ALLOW_INVALID_DATES';

CREATE SCHEMA IF NOT EXISTS `feedback` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci ;
USE `feedback` ;

-- -----------------------------------------------------
-- Table `feedback`.`application`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`application` (
  `application_id` INT NOT NULL AUTO_INCREMENT,
  `app_name` VARCHAR(45) NULL,
  PRIMARY KEY (`application_id`),
  UNIQUE INDEX `app_name_UNIQUE` (`app_name` ASC))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `feedback`.`user`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`user` (
  `user_id` INT NOT NULL AUTO_INCREMENT,
  `firstname` VARCHAR(45) NOT NULL,
  `lastname` VARCHAR(45) NULL,
  `email` VARCHAR(45) NOT NULL,
  `customer_length` VARCHAR(45) NULL,
  PRIMARY KEY (`user_id`))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `feedback`.`users_has_application`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`users_has_application` (
  `user_id` INT NOT NULL,
  `application_id` INT NOT NULL,
  PRIMARY KEY (`user_id`, `application_id`),
  INDEX `fk_users_has_application_application1_idx` (`application_id` ASC),
  INDEX `fk_users_has_application_users_idx` (`user_id` ASC),
  CONSTRAINT `fk_users_has_application_users`
    FOREIGN KEY (`user_id`)
    REFERENCES `feedback`.`user` (`user_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_users_has_application_application1`
    FOREIGN KEY (`application_id`)
    REFERENCES `feedback`.`application` (`application_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `feedback`.`survey`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`survey` (
  `survey_id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(45) NULL,
  `description` VARCHAR(255) NULL,
  `is_active` TINYINT(1) NULL,
  PRIMARY KEY (`survey_id`))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `feedback`.`question`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`question` (
  `question_id` INT NOT NULL,
  `question_text` VARCHAR(255) NULL,
  PRIMARY KEY (`question_id`))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `feedback`.`option`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`option` (
  `option_id` INT NOT NULL AUTO_INCREMENT,
  `question_id` INT NOT NULL,
  `option_number` INT NOT NULL,
  `option_text` TEXT NULL,
  INDEX `fk_option_question1_idx` (`question_id` ASC),
  PRIMARY KEY (`option_id`),
  UNIQUE INDEX `uk_question_option_number_key` (`question_id` ASC, `option_number` ASC),
  CONSTRAINT `fk_option_question1`
    FOREIGN KEY (`question_id`)
    REFERENCES `feedback`.`question` (`question_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `feedback`.`answer`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`answer` (
  `answer_id` INT NOT NULL AUTO_INCREMENT,
  `user_id` INT NOT NULL,
  `option_id` INT NOT NULL,
  `date_submitted` DATETIME NOT NULL,
  PRIMARY KEY (`answer_id`),
  INDEX `fk_answer_user1_idx` (`user_id` ASC),
  INDEX `fk_answer_option1_idx` (`option_id` ASC),
  CONSTRAINT `fk_answer_user1`
    FOREIGN KEY (`user_id`)
    REFERENCES `feedback`.`user` (`user_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_answer_option1`
    FOREIGN KEY (`option_id`)
    REFERENCES `feedback`.`option` (`option_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `feedback`.`survey_has_question`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `feedback`.`survey_has_question` (
  `survey_id` INT NOT NULL,
  `question_id` INT NOT NULL,
  `question_number` INT NULL,
  PRIMARY KEY (`survey_id`, `question_id`),
  INDEX `fk_survey_has_question_question1_idx` (`question_id` ASC),
  INDEX `fk_survey_has_question_survey1_idx` (`survey_id` ASC),
  UNIQUE INDEX `unique_order_key` (`survey_id` ASC, `question_number` ASC),
  CONSTRAINT `fk_survey_has_question_survey1`
    FOREIGN KEY (`survey_id`)
    REFERENCES `feedback`.`survey` (`survey_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_survey_has_question_question1`
    FOREIGN KEY (`question_id`)
    REFERENCES `feedback`.`question` (`question_id`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;


SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;

错误:

#1005 - Can't create table 'feedback.answer' (errno: 150)

我正在以此为模板创建我的表格:

https://dba.stackexchange.com/questions/16002/survey-database-design-associate-an-answer-to-a-user/16047#16047

我将 answer_id 添加到答案表的想法是,我希望用户能够多次填写同一个调查表。

为什么答题表会报错?

编辑: 服务器版本:5.5.29-0ubuntu0.12.04.2 我正在使用 phpmyadmin 导入它

【问题讨论】:

  • 也许这个问题有帮助:stackoverflow.com/questions/1457305/… 但我看不到您缺少的任何要求。
  • 我在没有创建反馈数据库的情况下在 sqlfiddle 中编写了它,它可以工作。我不确定这会是什么问题。
  • 我也尝试在 sqlfiddle 中重新创建它,但不能。也许这与更改默认字符集或排序规则有关,因为 sqlfiddle 不会让我摆弄这些。
  • 我删除了模式创建和对反馈数据库的引用,它创建了整个东西:sqlfiddle.com/#!2/32d00

标签: mysql database-design mysql-workbench


【解决方案1】:

您的代码在 MYSQL server 5.1 上运行没有错误。

errno: 150 的常见原因是当您创建引用尚不存在的 PK 的 FK 约束时。确保在创建“答案”表之前先创建“用户”表和“选项”表。

为了帮助调试,您可以一次删除一个 FK 约束,看看是哪一个触发了问题。

如果您按照显示的顺序执行代码,我看不出会出现任何 FK 问题。

【讨论】:

  • 奇数。为什么它对我不起作用?我用我的服务器详细信息更新了问题。我仍然在它上面启动调试过程,看看问题是什么。
【解决方案2】:

试试这个

 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL,ALLOW_INVALID_DATES';

-- -----------------------------------------------------
-- Table `feedback`.`application`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `application` (
`application_id` INT NOT NULL AUTO_INCREMENT,
`app_name` VARCHAR(45) NULL,
PRIMARY KEY (`application_id`),
UNIQUE INDEX `app_name_UNIQUE` (`app_name` ASC))
;

your working code in fiddle

【讨论】:

  • 使用 mysql 5.5.29 #1005 仍然出现同样的错误 - 无法创建表 'feedback.answer' (errno: 150)
  • 哦,我用你的代码和我的。我误解了你想让我只用你的。让我试试
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-02-19
  • 2020-04-10
  • 2013-07-22
  • 2017-04-09
  • 2016-10-12
  • 1970-01-01
相关资源
最近更新 更多