MySql约束问题

MySql约束问题,mysql,Mysql,取回最终形式的视图定义 没什么可拿的 在服务器中执行SQL脚本会导致: ERROR: Error 1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'CONSTRAINT `fk_employee_department` FOREIGN KEY (`dpt_id`) R

取回最终形式的视图定义

没什么可拿的

在服务器中执行SQL脚本会导致:

ERROR: Error 1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'CONSTRAINT `fk_employee_department`
FOREIGN KEY (`dpt_id`)
REFERENCES `r' at line 16
SQL代码:

    CREATE TABLE IF NOT EXISTS `rrm17b`.`employee` (
      `emp_id` INT UNSIGNED NOT NULL AUTO_INCREMENT,
      `dpt_id` INT UNSIGNED NULL,
      `emp_first` VARCHAR(20) NOT NULL,
      `emp_last` VARCHAR(20) NOT NULL,
      `emp_type` ENUM('f', 'p') NOT NULL,
      `emp_street` VARCHAR(30) NOT NULL,
      `emp_city` VARCHAR(20) NOT NULL,
      `emp_state` CHAR(2) NOT NULL,
      `emp_zip` INT UNSIGNED NOT NULL,
      `emp_phone` BIGINT UNSIGNED NOT NULL,
      `emp_email` VARCHAR(45) NOT NULL,
      `emp_notes` VARCHAR(100) NULL,
      PRIMARY KEY (`emp_id`),
      INDEX `fk_employee_department_idx` (`dpt_id` ASC) 
      CONSTRAINT `fk_employee_department`
        FOREIGN KEY (`dpt_id`)
        REFERENCES `rrm17b`.`department` (`dpt_id`)
        ON DELETE NO ACTION
        ON UPDATE NO ACTION)
    ENGINE = InnoDB
SQL脚本执行完成:语句:9成功,1失败

取回最终形式的视图定义。 没有要获取的内容

请尝试以下操作:

CREATE TABLE IF NOT EXISTS rrm17b.employee(
emp_id INT UNSIGNED NOT NULL AUTO_INCREMENT,
dpt_id INT UNSIGNED NULL,
emp_first VARCHAR(20) NOT NULL,
emp_last VARCHAR(20) NOT NULL,
emp_type ENUM('f', 'p') NOT NULL,
emp_street VARCHAR(30) NOT NULL,
emp_city VARCHAR(20) NOT NULL,
emp_state CHAR(2) NOT NULL,
emp_zip INT UNSIGNED NOT NULL,
emp_phone BIGINT UNSIGNED NOT NULL,
emp_email VARCHAR(45) NOT NULL,
emp_notes VARCHAR(100) NULL,
      PRIMARY KEY (emp_id),
      INDEX fk_employee_department_idx(dpt_id ASC),
      CONSTRAINT fk_employee_department
      FOREIGN KEY (dpt_id)
      REFERENCES rrm17b.department(dpt_id) ON DELETE NO ACTION ON UPDATE NO ACTION) ENGINE = InnoDB
修复了多个问题:

--在索引后添加逗号


--删除了dpt_id之后的“`”

在constraintFirst之前缺少逗号,您应该得到堆栈溢出的教程..我添加了逗号,现在我得到了以下结果:错误:错误1064:您的SQL语法有错误;查看与MySQL服务器版本对应的手册,以了解使用“INDEX
fk_department\u division 1\u idx”(
div_id
ASC)附近的正确语法,第15I行的约束“fk_department”找出了问题所在,就像前面所说的逗号,并且有一个空的额外表产生了问题。修正了一些常见的日期错误(忘记了2月有28天),我获得了一个成功的正向工程。谢谢所有帮助我的人。