0

我有一张桌子,其中特定的服务提供商将在那里存储例如汽车商店。汽车商店提供各种服务。

我的问题如何将这些服务存储在一个列中?我可以创建第二个表来存储服务,但如果我想提供搜索功能,这将是必需的——我的意图不是,至少现在不是。

那么我将如何将所有服务存储在一行中(对应于 eaxmple 的特定汽车商店)。如我所见,它将是 VARCHAR 类型。

此外,一个表中的主键是否可以引用另一个表中的主键?

我还需要做什么?

我还需要强调,在某些情况下,服务提供商可能提供独特的服务——只有一个服务提供商提供特定服务。

4

1 回答 1

1

你可以有多对多的关系,

此表存储服务提供者列表。

CREATE TABLE ServiceProvider
(
    ProviderID INT NOT NULL,
    ProviderName VARCHAR(50),
    .......,
    CONSTRAINT tb_pk PRIMARY KEY (ProviderID),
    CONSTRAINT tb_uq UNIQUE (ProviderName)
);

CREATE TABLE ServiceList
(
    ServiceID INT NOT NULL,
    ServiceName VARCHAR(50),
    .......,
    CONSTRAINT tba_pk PRIMARY KEY (ServiceID),
    CONSTRAINT tba_uq UNIQUE (ServiceName)
);

此表将服务提供商列表映射到他们提供的服务。

CREATE TABLE Provider_Service
(
    RecID INT,
    ProviderID INT NOT NULL,
    ServiceID INT NOT NULL,
    CONSTRAINT tbb_pk PRIMARY KEY (RecID),
    CONSTRAINT tbb_fk1 FOREIGN KEY (ProviderID) 
          REFERENCES  ServiceProvider(ProviderID),
    CONSTRAINT tbb_fk2 FOREIGN KEY (ServiceID) 
          REFERENCES  ServiceList(ServiceID),
    CONSTRAINT tba_uq UNIQUE (ServiceName, ProviderID)
);
于 2012-10-30T11:38:17.103 回答