如何防止 SQL Server 表中的重复

Posted

技术标签:

【中文标题】如何防止 SQL Server 表中的重复【英文标题】:How to prevent from duplicates in SQL Server table 【发布时间】:2013-08-13 14:54:13 【问题描述】:

我是 SQL Server 的新手。我在 Access 中创建了一个数据库并在那里定义了我的关系。在此之后,我使用 SQL Server 导入和导出数据工具来转换数据库并在 SQL Server 中使用。我的表结构如下:

Student            Course             Course-Module    Module          
-------------      -------------      -------------    -------------
TagID (PK)         CourseID (PK)      CourseID (FK)    ModuleID (PK)
StudentName        CourseName         ModuleID (FK)    ModuleName
CourseID                                                             

Module-Session     Session            Atendance
--------------     --------------     --------------
ModuleID  (FK)     SessionID (PK)     TagID     (FK)
SessionID (FK)     SessionName        SessionID (FK)       
                   SessionDate        ScanningTime
                   SessionTimeStart
                   SessionTimeEnd

我开发了一个查询,它将为给定的TagID 找到当前的SessionID,并将结果连同插入时间一起插入到Attendance 表中。

我的查询是(VS C# 语法)

string query = @"INSERT INTO Attendance " +
               "SELECT s.TagID, se.SessionID, " +
               " @todaysDate " +
               " AS ScanningTime " +
               " FROM (((Student s " +
               " LEFT JOIN [CourseID-ModuleID] cm ON s.CourseID = cm.CourseID) " +
               " LEFT JOIN [ModuleID-SessionID] ms ON cm.ModuleID = ms.ModuleID) " +
               " LEFT JOIN [Session] se ON ms.SessionID = se.SessionID) " +
               " WHERE s.TagID = @tagNo " +
               " AND se.SessionDate = cast(getdate() as date) " +
               " AND se.SessionTimeStart <= @Plus30Min " +
               " AND se.SessionTimeEnd >= @Plus30Min ";

查询运行,产生预期结果并将它们插入Attendance 表。

我的问题是我想让Attendance 表的TagIDSessionID 字段是唯一的,即我希望一个学生只注册一次特定会话,而不是像现在可能的那样多次注册.

编辑:

我的问题的一个例子。学生扫描一个标签,结果放在出勤表中:

Attendance
--------------------------------------
TagID      SessionID      ScanningTime
4820427      Test1    2013-08-13 15:10:02.590

几秒钟后,学生再次尝试扫描,结果被添加为新记录

Attendance
--------------------------------------
TagID      SessionID      ScanningTime
4820427      Test1    2013-08-13 15:10:02.590
4820427      Test1    2013-08-13 15:10:09.103

这是我想要避免的。我只想让学生扫描一次(所以它应该只允许一个记录与 4820427 和 Test1 的组合)。如果他再试一次,应该会弹出错误消息。

【问题讨论】:

所以你想改变只插入唯一主键的INSERT?你有什么样的重复,显示一些示例数据和预期的结果(并从查询中删除 C# 代码,否则我们无法复制和粘贴它)。 【参考方案1】:

将 TagID 和 SessionID 作为主键,复合键。

open design view,
choose the two fk keys.
and make as primarykey.

【讨论】:

但是 OP 已经注意到 PK 两者,所以我假设它们已经是主键。 考勤表有 2 个外键,不是主键 在设计视图中我只能设置考勤表的 1 个主键 您应该可以检查多个字段,您使用的是什么版本?否则使用 sql 使唯一约束主键聚集。我也会把代码放在答案中。【参考方案2】:

只需创建一个 UNIQUE constraint... 这正是它们的用途。

ALTER TABLE Attendance ADD CONSTRAINT UNIQUE NONCLUSTERED
(
    TagID,
    SessionID
)

【讨论】:

您能详细说明一下吗?我对 SQL 完全陌生 这样的接缝应该会有所帮助。是否可以同时在两个列上创建唯一约束? 非常感谢先生!

以上是关于如何防止 SQL Server 表中的重复的主要内容,如果未能解决你的问题,请参考以下文章

如何从 SQL Server 中的表中删除重复行 [重复]

防止 SQL 表中的重复值

从 excel 导入数据时防止 SQL Server 2008 中的行重复

SQL Server 表中存在 UDT [重复]

如何获取在 SQL Server 内部数据库的不同表中重复的列[重复]

使用另一个表中的内容更新 SQL Server 表[重复]