我在添加引用另一个表的外键字段时遇到问题。
首先,我创建了用户表,如下所示:
CREATE TABLE users (
user_id INT(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
userName VARCHAR(256) NOT NULL,
userEmail VARCHAR (256) NOT NULL,
userPwd VARCHAR(256) NOT NULL,
);
然后我希望测验表有一个外键来引用第一个表中的 user_id
CREATE TABLE quizzes (
quizId INT(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
quizName VARCHAR(128) NOT NULL,
quizMax SMALLINT(6) NOT NULL,
FOREIGN KEY (user_id) REFERENCES users (user_id)
);
这会引发错误:“表中不存在键列“user_id”。
其他答案建议检查 DB 是否为 InnoDB,我确实这样做了,而且确实如此。
无法理解为什么它告诉我 user_id 不存在,而它显然存在于用户表中。
首先检查表是否user
由于最后一列上附加了“,”,已成功创建!
其次,您提到的专栏FOREIGN KEY(user_id)
未在表中定义quizzes
,您需要添加此列quizzes
table.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)