CodeGo.net>如何防止在SQL Server表重复
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了CodeGo.net>如何防止在SQL Server表重复,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2241字,纯文字阅读大概需要4分钟。
内容图文
![CodeGo.net>如何防止在SQL Server表重复](/upload/InfoBanner/zyjiaocheng/882/a39f3c15a34a45c9a7179558ce0ed48f.jpg)
我是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
)
内容总结
以上是互联网集市为您收集整理的CodeGo.net>如何防止在SQL Server表重复全部内容,希望文章能够帮你解决CodeGo.net>如何防止在SQL Server表重复所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。