【发布时间】:2019-03-08 13:02:49
【问题描述】:
我制作了一个 EER 图,我正在尝试对其进行转发工程,但我收到此错误,但我找不到错误。
在服务器中执行 SQL 脚本 ERROR: Error 1064: You have an error in 你的 SQL 语法;检查与您的 MariaDB 对应的手册 在 'INDEX 附近使用正确语法的服务器版本
fk_User_Wallets1_idx(Wallets_idWalletsASC) 可见,约束' 在第 13 行
SQL 代码:
CREATE TABLE IF NOT EXISTS `mydb`.`User` (
`idUser` INT NOT NULL AUTO_INCREMENT,
`name` VARCHAR(45) NULL,
`email` VARCHAR(45) NULL,
`adress` VARCHAR(45) NULL,
`password` VARCHAR(45) NULL,
`saldo` INT NULL,
`date_start` DATETIME NULL,
`date_end` DATETIME NULL,
`Rolls_idRolls` INT NOT NULL,
`Wallets_idWallets` INT NOT NULL,
PRIMARY KEY (`idUser`, `Rolls_idRolls`, `Wallets_idWallets`),
INDEX `fk_User_Rolls1_idx` (`Rolls_idRolls` ASC) VISIBLE,
INDEX `fk_User_Wallets1_idx` (`Wallets_idWallets` ASC) VISIBLE,
CONSTRAINT `fk_User_Rolls1`
FOREIGN KEY (`Rolls_idRolls`)
REFERENCES `mydb`.`Rolls` (`idRolls`)
ON DELETE NO ACTION
ON UPDATE NO ACTION,
CONSTRAINT `fk_User_Wallets1`
FOREIGN KEY (`Wallets_idWallets`)
REFERENCES `mydb`.`Wallets` (`idWallets`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB
SQL script execution finished: statements: 11 succeeded, 1 failed
Fetching back view definitions in final form.
Nothing to fetch
【问题讨论】:
-
结束括号是否意味着在查询的末尾?
ON UPDATE NO ACTION) ENGINE = InnoDB似乎结束部分在创建语句ENGINE = InnoDB之外浮动。 -
你应该检查你的mysql版本中是否有不可见的索引。你在哪个版本? mysqlserverteam.com/mysql-8-0-invisible-indexes
-
(unrelated) 这个 PK 看起来很奇怪:PRIMARY KEY (
idUser,Rolls_idRolls,Wallets_idWallets) -- 因为idUser在逻辑上是唯一的,而PRIMARY KEY意味着唯一 --为什么列出了其他列?
标签: mysql sql mariadb mysql-workbench