c# - SQL Server表中如何防止重复

标签 c# sql sql-server database tsql

我是 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 是唯一的,即我希望一个学生只为特定 session 注册一次,而不是像现在这样多次注册。

编辑:

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

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 的组合)。如果他再试一次,就会弹出错误消息。

最佳答案

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

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

关于c# - SQL Server表中如何防止重复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18212436/

相关文章:

php - MySQL - 检查查询的前 6 个字符以确保它是 SELECT 是否安全?

sql - 如何在 JSON 键的 postgres 更新语句中增加值

sql-server - SQL 2000 'TRY CATCH like' 错误处理

mysql - SQL QUERY - UNION - 多个相同的表需要很长时间

c# - 如何在 C# 中使用类型化数据集?

用于清理 html 的 C# 库

mysql - 帮我优化这个 MySql 查询

mysql - 将 SQL 链接到 Access,重新查询显示 #Deleted

c# - 新添加成员后反序列化类时出现问题

javascript - jquery datepicker 和 asp.net c# 空值