dnuq 2015-02-04 06:19 采纳率: 0%
浏览 1542

使一个表自引用报错,,,,,,

CREATE TABLE [dbo].Employees NOT NULL,
。。。。。(省略了)
[**ManagerEmpID**] [int] NOT NULL)
然后又加了一个外键(引用本表的),
ALTER TABLE Employees
ADD CONSTRAINT FK_EmployeeHasManager
Foreign key (**ManagerEMPID**) REFERENCES Employees(**_EmployeeID_**)
但插入数据时会报错,书中说,应该先插入一条数据 ,然后再加外键 ,“可是还是会报错,ALTER TABLE 语句与 FOREIGN KEY SAME TABLE 约束"FK_EmployeeHasManager"冲突。该冲突发生于数据库"Accounting",表"dbo.Employees",
column 'EmployeeID'。求给力啊

  • 写回答

1条回答 默认 最新

  • save4me 2015-02-04 08:31
    关注

    因为你有外键约束,所以每个记录的ManagerEMPID必须是以及存在于数据库表里面的EmployeeID。
    首先添加一条记录,这个员工是可能是老板,所以他的ManagerEMPID是自己的EmployeeID。然后在添加老板的下级员工,因为这个时候ManagerEMPID可以是数据库里面已经存在的员工ID了。

    评论

报告相同问题?

悬赏问题

  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制