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

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'。求给力啊

sql

1个回答

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

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐