A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 高宜 中级黑马   /  2012-5-12 17:35  /  2113 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

SQL中如果TOP不能用于合计函数,有没什么方法解决

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

5 个回复

倒序浏览
SQL中Top可以用于合计函数

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
create table TopText(id int,A int,B int);
insert into TopText(id,A,B) values(1,23,15);
insert into TopText(id,A,B) values(2,13,5);
insert into TopText(id,A,B) values(3,31,7);
insert into TopText(id,A,B) values(4,5,27);
insert into TopText(id,A,B) values(5,16,47);
insert into TopText(id,A,B) values(6,22,19);
insert into TopText(id,A,B) values(7,21,13);

select id,top 5(A+B) as C from TopText order by C DESC;--报错
--消息:
--消息 156,级别 15,状态 1,第 1 行
--关键字 'top' 附近有语法错误。

评分

参与人数 1技术分 +2 收起 理由
宋天琪 + 2

查看全部评分

回复 使用道具 举报
本帖最后由 高宜 于 2012-5-13 18:31 编辑

如果用 select number,top 5 datediff(mi,startTime,EndTime) from table1;也会报同样的错误
回复 使用道具 举报
试试这个  select itop 5((A+B)as C,id)  from TopText order by C DESC

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
谢了! select top 5 (A+B) as C,id from TopText order by C DESC
换到前面后不报错了
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马