【问题标题】:Error Code: 1822. Failed to add the foreign key constraint. Missing index for constraint 'employee_ibfk_1' in the referenced table 'Address'错误代码:1822。添加外键约束失败。引用表“地址”中的约束“employee_ibfk_1”缺少索引
【发布时间】:2019-04-19 09:26:34
【问题描述】:

创建了两个表,即Address 和Employee.With 关系员工有一个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));

但在尝试创建员工表时出现以下错误:

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

【问题讨论】:

    标签: java sql hibernate


    【解决方案1】:

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

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

    【讨论】:

      【解决方案2】:

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

      像这样,

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

      【讨论】:

        【解决方案3】:

        需要在地址表中添加主键约束,才能在员工表中添加外键引用

        试试下面的代码:

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

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2014-12-07
          • 2019-02-27
          • 2019-06-06
          • 1970-01-01
          • 1970-01-01
          • 2017-09-16
          • 2016-05-23
          • 1970-01-01
          相关资源
          最近更新 更多