私は SQL Server を初めて使用します。Access で DB を作成し、そこで関係を定義しました。この後、SQL Server Import and Export Data ツールを使用して DB を変換し、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
テーブルを一意にしたいということです。つまり、1人の学生が特定のセッションに1回だけ登録し、現在可能なように複数回登録したいということです。SessionID
Attendance
編集:
私の問題の例。生徒がタグをスキャンすると、結果が出席テーブルに配置されます。
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の組み合わせで1つのレコードのみを許可する必要があります)。彼がもう一度やろうとすると、エラーメッセージがポップアップするはずです.