取分组前三第记录
代码如下 | 复制代码 |
SELECT 课程, |
取分组第一第记录
例
表Demo的数据都是字符串类型,按照顺序的时间Time(也是字符串)排序的记录如下:
Num Name Time
1 a 2009/05/01
1 a 2009/05/02
1 a 2009/05/03
2 b 2009/05/04
2 b 2009/05/05
3 c 2009/05/06
3 c 2009/05/07
5 e 2009/05/08
1 a 2009/05/09
1 a 2009/05/10
我想输出类似按照Num分组的每组的第一条数据记录,比如上面的记录我想操作后得到如下记录:
Num Name Time
1 a 2009/05/01
2 b 2009/05/04
3 c 2009/05/06
5 e 2009/05/08
1 a 2009/05/09
sql代码
代码如下 | 复制代码 |
declare @Tab table
select * from @Tab t where not exists(select 1 from @Tab where num=t.num and [time]
/*
(4 行受影响) |
取分组最大记录
示例:test 表 a b c
1 5 abc
2 6 bcd
1 7 ade
2 8 adc
若取按a列分组后,b列最大,的所有列的记录:
result a b c
1 6 bcd
2 8 adc
可以使用如下语句:
代码如下 | 复制代码 |
select * from test where b in (select max(id) from test group by a) 适用于所有数据库: select t1.a,t1.b,t1.c from test t1 inner join (seelct a,max(b) as b from test group by a) t2 on t1.a=t2.a and t1.b=t2.b 适用于所有数据库: select a,b,c from( select a,b,c ,row_number()over(partition by a order by b desc) rn from test ) where rn=1 |