mysql workbench生成的sql代码中出现错误1064

j8yoct9x  于 2021-06-15  发布在  Mysql
关注(0)|答案(1)|浏览(847)

我在mysql工作台中创建第一个表时遇到了一个小问题。当我创建两个表并查看正向工程进度时,我得到如下消息:
在服务器中执行sql脚本错误:错误1064:您的sql语法有错误;检查与您的mariadb服务器版本相对应的手册,了解使用“index”附近的正确语法 fk_person_has_user_person_idx ( person_ID asc)可见,第8行的“约束”
sql代码:

-- -----------------------------------------------------
        -- Table `customers`.`person_has_user`
        -- -----------------------------------------------------
        CREATE TABLE IF NOT EXISTS `customers`.`person_has_user` (
          `person_ID` INT NOT NULL,
          `user_person_ID` INT NOT NULL,
          PRIMARY KEY (`person_ID`, `user_person_ID`),
          INDEX `fk_person_has_user_user1_idx` (`user_person_ID` ASC) VISIBLE,
          INDEX `fk_person_has_user_person_idx` (`person_ID` ASC) VISIBLE,
          CONSTRAINT `fk_person_has_user_person`
            FOREIGN KEY (`person_ID`)
            REFERENCES `customers`.`person` (`ID`)
            ON DELETE NO ACTION
            ON UPDATE NO ACTION,
          CONSTRAINT `fk_person_has_user_user1`
            FOREIGN KEY (`user_person_ID`)
            REFERENCES `customers`.`user` (`person_ID`)
            ON DELETE NO ACTION
            ON UPDATE NO ACTION)
        ENGINE = InnoDB

SQL script execution finished: statements: 7 succeeded, 1 failed

Fetching back view definitions in final form.
Nothing to fetch

有人能解释一下吗?

vd8tlhqk

vd8tlhqk1#

埃德·科特雷尔是对的。这是mysql服务器版本和mysql工作台设置之间的版本不匹配。
SELECT VERSION(); 让你的服务器告诉你它的版本。
在workbench中,编辑/preferences/modeling>mysql,并将默认的目标mysql版本设置为您的服务器版本。
然后workbench将生成适合您实际使用的服务器的代码。
这个错误很可能发生在新用户身上;新下载的workbench软件默认设置为MySQL8,但是世界上很多服务器还没有安装版本8。

相关问题