0

我制作了具有一个主键和一个外键的经典 Employee - Employer 表。外键引用主要的,因此它是一个自引用表:

CREATE TABLE Worker
(
    OIB NUMERIC(2,0),
    Name NVARCHAR(10),
    Surname NVARCHAR(20),
    DateOfEmployment DATETIME2 NOT NULL,
    Adress NVARCHAR(20),
    City NVARCHAR(10),
    SUPERIOR NUMERIC(2,0) UNIQUE,
    Constraint PK_Worker PRIMARY KEY(OIB),
    CONSTRAINT FK_Worker FOREIGN KEY (Superior) REFERENCES Worker(OIB)
);

应该为我的所有员工保留积分的第二张表是这样制作的:

CREATE TABLE Point
(
    OIB_Worker NUMERIC(2,0) NOT NULL,
    OIB_Superior NUMERIC(2,0) NOT NULL,
    Pt_To_Worker tinyint,
    Pt_To_Superior tinyint,
    Month_ INT NOT NULL,
    Year_ INT NOT NULL,
    CONSTRAINT FK_Point_Worker FOREIGN KEY (OIB_Worker) References Worker(OIB),
    CONSTRAINT FK_Point_Worker_2 FOREIGN KEY (OIB_Superior) References Worker(Superior),
    CONSTRAINT PK_Point PRIMARY KEY(OIB_Worker,OIB_Superior,Month_,Year_)
);

它应该能够为每个员工每月存储成绩。也就是说,我有两个外键,一个用于 Worker.OIB,一个用于 Worker.Superior。此外,我有一个由 Point.OIB_Worker、Point.OIB_superior、Point.Month_ 和 Point.Year_ 列组成的复合主键。键是复合的,因为它需要每月一次以上禁用输入成绩。

我的问题是:

如何制作从Point到Worker的外键,以便任何上级都可以分配一个以上的员工?

如果你仔细观察,我的实施是有效的,但每个经理只能有一名员工。这是因为外键必须引用其他表中的主列或唯一列。而我的 Worker.Superior 是唯一的,所以它只能有唯一的值(没有重复)。

我想很多人会觉得这个例子很有趣,因为它是创建新数据库时的常见问题。

4

2 回答 2

0

我认为您的 FK_Point_Worker_2 也应该有 References Worker(OIB),并且您应该从 Worker.Superior 中删除 UNIQUE 约束。这样,一个上级就可以有多个工人分配给他。

于 2013-03-18T18:47:15.783 回答
0

想想看。你对 SUPERIOR 有独特的限制,你对为什么两个员工不能拥有相同的 SUPERIOR 感到困惑。这就是唯一约束所做的 - 不允许重复。

FK 只能引用一个或多个唯一列。

带有 References Worker (OIB) 的 FK_Point_Worker_2 并不能保证 OIB 是一个上级。

我将在(OIB,SUPERIOR)上的 Worker 上添加一个唯一约束,
并删除 SUPERIOR 上的唯一约束。
它永远是独一无二的,因为 OIB 是独一无二的。然后有复合FK关系。

这是复合 FK 关系的示例

ALTER TABLE [dbo].[wfBchFolder]  WITH CHECK ADD  CONSTRAINT [FK_wfBchFolder_wfBch] FOREIGN KEY([wfID], [bchID])
REFERENCES [dbo].[WFbch] ([wfID], [ID])
GO
于 2013-03-18T19:21:38.700 回答