0

我在 DB 有 4 个字段。我将它们设置为不能重复条目。它们是:

1. Model     Varchar(14)     Unique
2. Serial    varchar(8)      Unique
3. Lot       varchar(5)      Unique
4. Line      char(5)         Unique


                    Model         Serial             Lot             Line
First data        remocon         x0001              033a            fa 01

如果我输入了相同的数据,则无法记录。

 remocon         x0001              033a            fa 01

但是如果我输入如下,如何使这些数据成功输入:

remocon        x0002        033a            fa 01

我想要这样的结果:

 Model         Serial             Lot             Line
remocon         x0001             033a            fa 01
remocon         x0002             033a            fa 01
4

2 回答 2

6

您需要为所有字段添加唯一约束,而不是每个字段,即

UNIQUE(型号、序列号、批次、线路)

解决方案:

CREATE TABLE YourTable
(
 Model     Varchar(14)     NOT NULL,
 Serial    varchar(8)      NOT NULL,
 Lot       varchar(5)      NOT NULL,
 Line      char(5)         NOT NULL,
 unique    (model, serial, lot, line) 

)

对于现有表:

 alter table YourTableName drop index model;
 alter table YourTableName drop index serial;
 alter table YourTableName drop index lot;
 alter table YourTableName drop index line;
 alter table YourTableName add unique (model, serial, lot, line); 
于 2010-08-11T07:38:32.143 回答
0

如果为每个字段创建唯一约束,则每个字段都需要具有唯一数据。您需要创建一个包含所有无法重复的字段的 UNIQUE。

UNIQUE(Model, Serial, Lot, Line)

但是,如果您的所有字段都需要是唯一的,我认为您的表没有主键,您应该创建所有字段的主键而不是唯一。

于 2010-08-11T08:19:58.950 回答