用sql语句 从国家和获奖牌情况中查询国家和金牌数,并且先按金牌数降序,再按国家名称降序排列存储到表
用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,不好意思写错了!但我主要不明白为啥那样分组又那样排滴啊!
最佳回答
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(*)来统计一个国家名称所对应的记录数了。
热门文章
- 康达学院专转本五年制
- 高考一个考场分ab卷吗
- not only but also用法
- 某物体做自由落体运动,从释放开始计时,则物体在前2s内的平均速度为______m/s,物体下落2m时的速度大小为______m/s.
- 三角函数公式大全表格
- 地理中考必背知识点2022
- 2013-2014学年小学六年级科学上学期期末考试试卷及答案
- 人教版2014-2015学年小学五年级英语第二学期期中教学质量检测试卷及答案
- 【Linux驱动开发】设备树详解(二)设备树语法详解
- 别跟客户扯细节
- 在别的城市买房子能落户吗
- 卖房前要把装修贷还完吗
- 高中政治教学提高教学效果的方法探究
- “互联网+”背景下的初中英语课堂教学改革与创新策略研究
- 2022年终止合同范本
- 租房合同范本范文
- 如何挑选土豆
- 如何挑选土鸡
