sql 语句排序 在查询结果中按人数降序排列,若人数相同,则按课程号升序排列?

2024-12-03 19:02:49
推荐回答(3个)
回答1:

代码如下:

select xuehao as 学号,score as 总成绩 

from CJBwhere xuehao in(

select xuehao from XSB)

group by xuehao,score

order by score desc,xuehao

select id as 学号, sum(score) as 总成绩

from 成绩表

group by id

order by sum(score) desc, id asc

扩展资料

ORDER BY 语句用于对结果集进行排序。

ORDER BY 语句用于根据指定的列对结果集进行排序。

ORDER BY 语句默认按照升序对记录进行排序。

如果您希望按照降序对记录进行排序,可以使用 DESC 关键字。

order by 是用在where条件之后,用来对查询结果进行排序。

order by 字段名 asc/desc  。

asc 表示升序(默认为asc,可以省略)。

desc表示降序。

order by 无法用于子查询,否则会报错:除非另外还指定了 TOP 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效。

回答2:

请贴出具体的表结构

一般是这样的
select * from tableA order by col1 desc,col2 asc;
先按col1降序,相同则按col2 升序

回答3:

select * from t1 order by c1 desc, c2 asc