-1

我有一个分级数据库,如下所示:

StudentId | SubjectCode | Grade | DateApproved

Student1 | SUBJ1234 | - | 30-3-2012<br/>
Student1 | SUBJ1234 | 2.25 | 31-3-2012<br/>
Student1 | SUBJ45678 | 2.00 | 31-2012 

如果您注意到,有一个过时的副本,成绩为空白(用 表示"-")。

我想从数据库中选择所有有重复但更近的项目的空白等级,所以我可以删除它们。

我该怎么做SQL (MySql 5.5)

4

1 回答 1

1

你可以试试这个:

SELECT * 
   FROM yourTableName as t1 
   WHERE t1.Grade = "-" 
      AND EXISTS (SELECT * 
                     FROM yourTableName as t2 
                     WHERE t1.StudentId = t2.StudentId 
                         AND t1.SubjectCode = t2.SubjectCode 
                         AND t1.DateApproved < t2.DateApproved
                 )

该代码基本上从您的表中选择所有字段,这些字段的等级设置为-,并且有一条记录具有相同的StudentIdSubjectCode更高的(较新)DateApproved

编辑:如果您希望“新”记录具有已定义Grade(除 之外-),AND t2.Grade != '-'请在内部查询中的最后一个条件之后、右括号之前添加:

于 2012-04-09T07:34:51.613 回答