3

私は 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ための現在の値を見つけるクエリを開発しました。TagIDAttendance

私のクエリは(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回だけ登録し、現在可能なように複数回登録したいということです。SessionIDAttendance

編集:

私の問題の例。生徒がタグをスキャンすると、結果が出席テーブルに配置されます。

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つのレコードのみを許可する必要があります)。彼がもう一度やろうとすると、エラーメッセージがポップアップするはずです.

4

2 に答える 2

2

TagID と SessionID を主キー、複合キーにする。

open design view,
choose the two fk keys.
and make as primarykey.
于 2013-08-13T14:56:10.647 に答える
1

UNIQUE 制約を作成するだけです...まさにそれが目的です。

ALTER TABLE Attendance ADD CONSTRAINT UNIQUE NONCLUSTERED
(
    TagID,
    SessionID
)
于 2013-08-13T15:08:04.613 に答える