我在 MySQL InnoDB 中有一个这样创建的表:
CREATE TABLE `users` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`type` enum('MANUAL','FACEBOOK') NOT NULL DEFAULT 'MANUAL',
`role` enum('COOK','HOST','ALL') NOT NULL DEFAULT 'ALL',
`about_me` varchar(1000) DEFAULT NULL,
`food_preferences` varchar(1000) DEFAULT NULL,
`cooking_experience` varchar(1000) DEFAULT NULL,
`with_friend` bit(1) DEFAULT b'0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8
接下来我尝试使用这样的语句添加一个表(在创建表时没有添加外键,因为有问题):
CREATE TABLE `messages` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`from` bigint(20) NOT NULL,
`to` bigint(20) NOT NULL,
`content` varchar(10000) NOT NULL,
`timestamp_sent` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`timestamp_read` timestamp NULL DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
创建表后,我需要最后添加外键'from'
和'to'
引用'users'.'id'
字段的字段:
ALTER TABLE `messages`
ADD CONSTRAINT `messages_users_fk`
FOREIGN KEY (`from` , `to` )
REFERENCES `users` (`id` , `id` )
ON DELETE SET NULL
ON UPDATE CASCADE
, ADD INDEX `messages_users_fk_idx` (`from` ASC, `to` ASC)
我得到的错误是:
错误:错误 1822:无法添加外键约束。引用表 'users' 中的约束 'messages_users_fk' 缺少索引。
但是“用户”表有一个PRIMARY
索引'id'
...
还尝试采取更小的步骤并仅为'from'
字段添加外键:
ALTER TABLE `messages`
ADD CONSTRAINT `messages_users_fk`
FOREIGN KEY (`from` )
REFERENCES `users` (`id` )
ON DELETE SET NULL
ON UPDATE CASCADE
, ADD INDEX `messages_users_fk_idx` (`from` ASC) ;
错误略有不同:
错误:错误 1825:无法在表“消息”上添加外键约束。FOREIGN KEY 约束“cook4food/messages_users_fk”中的选项不正确。
bigint(20) NOT NULL
字段的类型与其他 StackOverflow 线程中建议的问题原因相同 ( )。我的表没有分区(MySQL 手册指出这是在 InnoDB 中具有外键约束的限制)。该'messages'
表当前不存储任何行,因此存储的数据不会成为任何问题。我被卡住了,请帮忙。