数据库
首页 > 数据库> > CodeGo.net>如何防止在SQL Server表重复

CodeGo.net>如何防止在SQL Server表重复

作者:互联网

我是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,并将结果与​​插入时间一起插入到出勤表中.

我的查询是(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 ";

查询运行,并产生预期结果并将其插入到出勤表中.

我的问题是我想使出勤表的字段TagID和SessionID唯一,即我希望一个学生仅一次一次就可以注册特定的会话,现在不能多次注册.

编辑:

我的问题的一个例子.学生扫描标签并将结果放置在出勤表中:

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的组合).如果他将再次尝试执行此操作,则会弹出错误消息.

解决方法:

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

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

标签:sql,c,sql-server,tsql,database
来源: https://codeday.me/bug/20191122/2063427.html