问题描述
- 使一个表自引用报错,,,,,,
-
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'。求给力啊
解决方案
因为你有外键约束,所以每个记录的ManagerEMPID必须是以及存在于数据库表里面的EmployeeID。
首先添加一条记录,这个员工是可能是老板,所以他的ManagerEMPID是自己的EmployeeID。然后在添加老板的下级员工,因为这个时候ManagerEMPID可以是数据库里面已经存在的员工ID了。
时间: 2024-09-13 04:11:47