用sql语句 从国家和获奖牌情况中查询国家和金牌数,并且先按金牌数降序,再按国家名称降序排列存储到表

学习 时间:2026-04-03 14:21:47 阅读:2583
用sql语句 从国家和获奖牌情况中查询国家和金牌数,并且先按金牌数降序,再按国家名称降序排列存储到表three.prg中!怎么先按金牌数降序,在按国家名称降序呢?select 国家名称,金牌数 from 国家,获奖牌情况;where 国家.国家代码=获奖牌情况.国家代码;group by 国家名称 order by 2 desc,国家名称 desc into table temp按国家名称分组 又order by 2 desc,国家名称 desc 怎么回事啊?不懂!按金牌数分组不行么【group by 金牌数】可以的话又怎样写啊?寻求完整正确的sql语句!是存放在表tamp中,不是three,不好意思写错了!但我主要不明白为啥那样分组又那样排滴啊!

最佳回答

传统的过客

害羞的香菇

2026-04-03 14:21:47

group by 国家名称:按国家名称分组可得到每个国家名称对应的金牌数量order by 2 desc,国家名称 desc:先根据第2个查询出来的字段也就是金牌数排序,desc指定降序。然后再根据“国家名称”排序,desc指定降序。order by 可以根据一个或几个字段进行排序,放在前面的优先。 再问: 如果 先写select 金牌数,国家名称from 国家,获奖牌情况;这样的话,那order by后面是写的1中的查询结果么。。。group by 国家名称 order by 1 desc,国家名称 desc 对不? 再答: 是的,order by后面可以根据字段名或者是查询出来的第几列进行排序。所以你改成这样的语句的话,order by 1和order by 金牌数 是一个意思。另外这里的group by 语句的用法有点问题。如果按照上面的语句查询的话,会报错的。SQL中用group by要显示的字段中除了分组的条件以外都必须是聚合函数。所以要实现这个查询应该是 select 国家名称, sum(金牌数) from 国家,获奖牌情况; where 国家。国家代码=获奖牌情况。国家代码; group by 国家名称 order by 2 desc,国家名称 desc 当然我不是很清楚获奖牌情况表的结构,如果是一个金牌一条记录的话,这里就用count(*)来统计一个国家名称所对应的记录数了。

最新回答共有2条回答

  • 魁梧的柜子
    回复
    2026-04-03 14:21:47

    group by 国家名称:按国家名称分组可得到每个国家名称对应的金牌数量order by 2 desc,国家名称 desc:先根据第2个查询出来的字段也就是金牌数排序,desc指定降序。然后再根据“国家名称”排序,desc指定降序。order by 可以根据一个或几个字段进行排序,放在前面的优先。 再问: 如果 先写select 金牌数,国家名称from 国家,获奖牌情况;这样的话,那order by后面是写的1中的查询结果么。。。group by 国家名称 order by 1 desc,国家名称 desc 对不? 再答: 是的,order by后面可以根据字段名或者是查询出来的第几列进行排序。所以你改成这样的语句的话,order by 1和order by 金牌数 是一个意思。另外这里的group by 语句的用法有点问题。如果按照上面的语句查询的话,会报错的。SQL中用group by要显示的字段中除了分组的条件以外都必须是聚合函数。所以要实现这个查询应该是 select 国家名称, sum(金牌数) from 国家,获奖牌情况; where 国家。国家代码=获奖牌情况。国家代码; group by 国家名称 order by 2 desc,国家名称 desc 当然我不是很清楚获奖牌情况表的结构,如果是一个金牌一条记录的话,这里就用count(*)来统计一个国家名称所对应的记录数了。

上一篇 设运功动员质量为50kg,每分钟跳绳180次,假定每次跳跃中,脚与地面接触时间为一次跳跃时间的2/5,则克服重力做功功率

下一篇 求介绍家庭情况的英文面试稿