错误代码:1822。无法添加外键约束。引用表“地址”中约束“ employee_ibfk_1”的缺少索引

时间:2019-04-19 09:26:34

标签: java sql hibernate

创建了两个表,即Address和Employee.With关系,employee具有一个n地址。数据库脚本如下。

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));

但是尝试创建employee表时出现以下错误:

  

错误代码:1822。无法添加外键约束。失踪   引用表中约束“ employee_ibfk_1”的索引   “地址” 0.117秒

2 个答案:

答案 0 :(得分:1)

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

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

答案 1 :(得分:1)

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

像这样

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);