取得分组 TOP-N 测试表与测试数据
CREATE TABLE TopnTest ( name VARCHAR(10), -- 姓名 procDate DATETIME, -- 处理时间 result INT -- 成绩 );
INSERT INTO TopnTest VALUES('张三', '2010-10-01 12:00:05', 80); INSERT INTO TopnTest VALUES('张三', '2010-10-01 12:20:05', 85); INSERT INTO TopnTest VALUES('张三', '2010-10-02 07:25:15', 79); INSERT INTO TopnTest VALUES('张三', '2010-10-02 10:30:05', 88); INSERT INTO TopnTest VALUES('张三', '2010-10-03 15:05:05', 86);
INSERT INTO TopnTest VALUES('李四', '2010-10-01 06:00:05', 60); INSERT INTO TopnTest VALUES('李四', '2010-10-04 08:00:05', 90); INSERT INTO TopnTest VALUES('李四', '2010-10-05 10:00:05', 75); INSERT INTO TopnTest VALUES('李四', '2010-10-08 11:00:05', 88); INSERT INTO TopnTest VALUES('李四', '2010-10-09 12:00:05', 60);
INSERT INTO TopnTest VALUES('王五', '2010-09-10 08:00:05', 70); INSERT INTO TopnTest VALUES('王五', '2010-09-14 08:00:05', 80); INSERT INTO TopnTest VALUES('王五', '2010-09-25 18:00:05', 75); INSERT INTO TopnTest VALUES('王五', '2010-09-28 18:00:05', 88); INSERT INTO TopnTest VALUES('王五', '2010-10-09 12:00:05', 70);
要求取得每个人的 最近2次处理时间的 详细记录情况。
思路如果仅仅是 一个人的 最近2次,那么直接 TOP 2 或者 Rownum <= 2 可以处理。 每个人的最近1次,也可以通过 SELECT MAX() GROUP BY 来实现。 每个人的最近2次,需要 自己和自己 关联,才能解决了。
实现SELECT * FROM TopnTest WHERE ( SELECT COUNT(1) FROM TopnTest subTopnTest WHERE TopnTest.name = subTopnTest.name AND TopnTest.procDate < subTopnTest.procDate ) < 2 ORDER BY name, procDate
执行结果name procDate result ---------- ----------------------- ----------- 李四 2010-10-08 11:00:05.000 88 李四 2010-10-09 12:00:05.000 60 王五 2010-09-28 18:00:05.000 88 王五 2010-10-09 12:00:05.000 70 张三 2010-10-02 10:30:05.000 88 张三 2010-10-03 15:05:05.000 86 |