SQL SERVER 查询特定的前几条数据

1. 使用MS SQL Server 2008; 2. 数据库内容如下:

insert into xuexi1 values('张三0', '数学', 98 )

insert into xuexi1 values('张三1', '数学',912 )

insert into xuexi1 values('张三2', '数学', 344 )

insert into xuexi1 values('张三3', '数学',546 )

insert into xuexi1 values('1张三4', '数学1', 498 )

insert into xuexi1 values('1张三5', '数学1', 198 )

insert into xuexi1 values('1张三6', '数学1', 983 )

insert into xuexi1 values('1张三7', '数学1', 982 )

insert into xuexi1 values('2张三4', '语文', 49 )

insert into xuexi1 values('2张三5', '语文', 19 )

insert into xuexi1 values('2张三6', '语文', 93 )

insert into xuexi1 values('2张三7', '语文', 92 )


3. 要查询的结果:每一门课程的前2名
忘了说了,刚才想问能不能只用一条语句?科目很多,如果这样查询觉得可能慢
select a.xingming,a.kemu,a.fenshu 
from xuexi1 a
where a.fenshu in 
(
SELECT top 2 fenshu
FROM xuexi1
WHERE
kemu=a.kemu
order by fenshu desc
)
字段名和表名都用拼音表示的,拼一下就知道是啥了,再一个,可能会报错,你再自己稍微修改一下吧,反正大概就这个意思
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值