为了账号安全,请及时绑定邮箱和手机立即绑定

错误代码:1822。添加外键约束失败。引用表“地址”中的约束“employee_ibfk_1”

错误代码:1822。添加外键约束失败。引用表“地址”中的约束“employee_ibfk_1”

慕标琳琳 2022-10-12 15:57:09
创建了两个表,即 Address 和 Employee.With 关系员工有一个地址。数据库脚本如下。create table address(addressid int,city varchar(10),pincode varchar(10));insert into address(addressid,city,pincode) values(201,'Hosur',635109);create table employee(empid int , firstname varchar(20),lastname varchar(20),department varchar(10),emailAddress varchar(50),baseLocation varchar(20),address int,FOREIGN KEY (Address) REFERENCES Address(addressId));但是在尝试创建员工表时出现以下错误:错误代码:1822。添加外键约束失败。引用表 'Address' 中的约束 'employee_ibfk_1' 缺少索引 0.117 秒
查看完整描述

3 回答

?
米脂

TA贡献1836条经验 获得超3个赞

您可能应该在 Address 表中的 addressid 上添加一个主键,这将创建所需的索引。在您当前的脚本中,不能保证 addressid 是唯一的,因此如果有重复,外键永远无法确定要引用哪一行。

create table address(addressId int primary key not null, city varchar(10), pincode varchar(10));



查看完整回答
反对 回复 2022-10-12
?
哔哔one

TA贡献1854条经验 获得超8个赞

您需要在地址表中添加主键约束,以便在员工表中添加外键引用


尝试使用以下代码:


create table address(addressid int primary key not null,city varchar(10),pincode varchar(10));


insert into address(addressid,city,pincode) values(201,'Hosur',635109);


create table employee(empid int , firstname varchar(20),lastname varchar(20),department varchar(10),emailAddress varchar(50),baseLocation varchar(20),address int,FOREIGN KEY  (address) REFERENCES address(addressid));



查看完整回答
反对 回复 2022-10-12
?
三国纷争

TA贡献1804条经验 获得超7个赞

因为外键引用主键。您在表地址中没有主键。


像这样,


create table address(addressid int primary key,city varchar(10),pincode varchar(10));


create table employee(empid int , firstname varchar(20),lastname varchar(20),department varchar(10),emailAddress varchar(50),baseLocation varchar(20),address int ,FOREIGN KEY (address) REFERENCES address(addressid));


insert into address(addressid,city,pincode) values(201,'Hosur',635109);


查看完整回答
反对 回复 2022-10-12
  • 3 回答
  • 0 关注
  • 162 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号