gpt4 book ai didi

mysql - 外键创建

转载 作者:行者123 更新时间:2023-11-29 18:15:47 25 4
gpt4 key购买 nike

我在向 MySQL 数据库中的表添加外键约束时遇到一些问题。

我有以下用户表:

CREATE TABLE `user` (
`Id` varchar(128) NOT NULL,
`Email` varchar(255) NOT NULL,
`EmailConfirmed` tinyint(1) NOT NULL,
`PasswordHash` longtext,
`SecurityStamp` longtext,
`PhoneNumber` longtext,
`PhoneNumberConfirmed` tinyint(1) NOT NULL,
`TwoFactorEnabled` tinyint(1) NOT NULL,
`LockoutEndDateUtc` datetime DEFAULT NULL,
`LockoutEnabled` tinyint(1) NOT NULL,
`AccessFailedCount` int(11) NOT NULL,
`UserName` varchar(255) NOT NULL,
PRIMARY KEY (`Id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1

这是我的用户通知表,我正在尝试添加外键:

CREATE TABLE `usernotice` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`notifySitemap` bit(1) NOT NULL,
`notifyRobots` bit(1) NOT NULL,
`user_id` varchar(128) DEFAULT NULL,
`health_site_id` int(11) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `user_constraint_idx` (`user_id`),
KEY `healthSiteId_idx` (`health_site_id`),
CONSTRAINT `healthSiteId` FOREIGN KEY (`health_site_id`) REFERENCES `health_site` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=utf8

我正在尝试引用 usernotice.user_id 列中的 user.id 列。为此,我使用以下 SQL:

ALTER TABLE usernotice
ADD CONSTRAINT userId
FOREIGN KEY (user_id)
REFERENCES user (Id)
ON DELETE NO ACTION
ON UPDATE NO ACTION;

当我执行此命令时,我收到错误代码 1215。谁能告诉我我做错了什么?

编辑:检查show create table查询后,我注意到所使用的字符集存在差异。使用另一个字符集重新创建 usernotice 表修复了此问题。

最佳答案

https://dev.mysql.com/doc/refman/5.5/en/create-table-foreign-keys.html外键和引用键中的对应列必须具有相似的数据类型。整数类型的大小和符号必须相同。字符串类型的长度不必相同。对于非二进制(字符)字符串列,字符集和排序规则必须相同。

你们的字符集不一样...

关于mysql - 外键创建,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47031627/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com