MySql Workbench 语法错误

MySql Workbench syntax error

编辑 :请​​先阅读问题 post 你的答案 :( 我知道 UNIQUE 不应该在这里。我使用 MySQL Workbench 来组织我的数据库,出于未知原因,它决定从今天早上开始就把 UNIQUE 放在这里。这就是问题所在。

当我创建 10 个具有许多关系的 table 时,我将我的数据库与来自 MySql Workbench 的图表同步。因为我到处都有一些 "UNIQUE",所以我无法真正同步任何东西,因为我遇到了错误。并将所有语句复制粘贴到记事本中以调试它们不是一个选项:p

问题是:为什么 MySql Workbench 将所有这些错误的 UNIQUE 放在 create table 语句中?

感谢您的帮助:)


当我尝试将模型与数据库同步时出现奇怪的错误。

create table语句出错:

CREATE TABLE IF NOT EXISTS `barometres`.`brm_questions` ( 
`id` INT(10) UNIQUE UNSIGNED NOT NULL AUTO_INCREMENT, 
`theme_id` INT(10) UNIQUE UNSIGNED NOT NULL, 
`question_type_id` TINYINT(3) NOT NULL, 
`type` TINYINT(1) NULL DEFAULT NULL, 
`reference` TINYINT(1) NULL DEFAULT NULL, 
`created_at` DATETIME NOT NULL, 
`updated_at` DATETIME NULL DEFAULT NULL, 
`deleted_at` DATETIME NULL DEFAULT NULL, 
INDEX `fk_brm_questions_brm_themes1_idx` (`theme_id` ASC), 
INDEX `fk_brm_questions_brn_questions-types1_idx` (`question_type_id` ASC), 
PRIMARY KEY (`id`), 
CONSTRAINT `fk_brm_questions_brm_themes1` 
FOREIGN KEY (`theme_id`) 
REFERENCES `barometres`.`brm_themes` (`id`) 
ON DELETE NO ACTION 
ON UPDATE NO ACTION, 
CONSTRAINT `fk_brm_questions_brn_questions-types1` 
FOREIGN KEY (`question_type_id`) 
REFERENCES `barometres`.`brn_questions-types` (`id`) 
ON DELETE NO ACTION 
ON UPDATE NO ACTION) 
ENGINE = InnoDB 
DEFAULT CHARACTER SET = utf8 

这是正常的,id 列不应该被标记为 UNIQUE(因为我没有在 Workbench 中检查它),UNSIGNED 应该在 UNIQUE 之前。

因为 UNSIGNED 在 UNIQUE 之后,我的模型中的每个 table 都出现了这个错误:

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 'UNSIGNED NOT NULL AUTO_INCREMENT, 
`theme_id` INT(10) UNIQUE UNSIGNED NOT NULL,' at line 2 

如您所见,theme_id 列也被标记为 UNIQUE,即使我也没有检查它。

我所有的 table 都有同样的问题,我真的不知道如何在不手动更改记事本中的所有语句的情况下解决它。

你知道为什么 workbench 有这种行为吗?这是Workbench6.3.9,同型号在6.3.6上出现同样的错误

非常感谢您的帮助。

安东尼

您错误地使用了 UNIQUE 关键字。它应该在列定义的末尾使用。

变化

`id` INT(10) UNIQUE UNSIGNED NOT NULL AUTO_INCREMENT

收件人

`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT -- UNIQUE keyword is removed

`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE

:
当您将字段定义为 PRIMARY.
时,您不需要显式 UNIQUE 选项 因为 PRIMARY 默认情况下是 UNIQUE。因此,由于字段 idPRIMARY KEY,请停止在其上使用 UNIQUE

要使列唯一,请在其上创建唯一索引。 Unique 关键字不应出现在列规范中。此外,通过将 id 列设为主键,它也是唯一的。

试试这个:

CREATE TABLE IF NOT EXISTS `barometres`.`brm_questions` ( 
    `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT, 
    `theme_id` INT(10) UNSIGNED NOT NULL, 
    `question_type_id` TINYINT(3) NOT NULL, 
    `type` TINYINT(1) NULL DEFAULT NULL, 
    `reference` TINYINT(1) NULL DEFAULT NULL, 
    `created_at` DATETIME NOT NULL, 
    `updated_at` DATETIME NULL DEFAULT NULL, 
    `deleted_at` DATETIME NULL DEFAULT NULL, 
    PRIMARY KEY (`id`), 
    INDEX `fk_brm_questions_brm_themes1_idx` (`theme_id` ASC), 
    INDEX `fk_brm_questions_brm_questions-types1_idx` (`question_type_id` ASC), 
    UNIQUE INDEX `fk_brm_questions_brm_theme_id` (`theme_id`),
    CONSTRAINT `fk_brm_questions_brm_themes1` 
        FOREIGN KEY (`theme_id`) 
        REFERENCES `barometres`.`brm_themes` (`id`) 
        ON DELETE NO ACTION 
        ON UPDATE NO ACTION, 
    CONSTRAINT `fk_brm_questions_brn_questions-types1` 
        FOREIGN KEY (`question_type_id`) 
        REFERENCES `barometres`.`brn_questions-types` (`id`) 
        ON DELETE NO ACTION 
        ON UPDATE NO ACTION
) 
ENGINE = InnoDB 
DEFAULT CHARACTER SET = utf8