如何防止SQL Server表中的重复

时间:2013-08-13 14:54:13

标签: c# sql sql-server database tsql

我是SQL Server新手。我在Access中创建了一个DB并在那里定义了我的关系。在此之后,我使用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

我开发了一个查询,它会找到给定SessionID的当前TagID,并将结果插入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表。

我的问题是我想让TagID表的字段SessionIDAttendance唯一,即我希望一个学生只注册特定会话ONCE,而不是多个现在可能的时间。

修改

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

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

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

2 个答案:

答案 0 :(得分:2)

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

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

答案 1 :(得分:1)

只需创建一个UNIQUE constraint ......这正是他们的目的。

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