创建了两个表,即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秒
答案 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);