如何在SQL中按多个列和不同方向进行排序。column1将按降序排序,column2将按升序排序。
当前回答
ORDER BY column1 DESC, column2
当两行或多行的column1字段相等时,这会先按column1(降序)排序,然后按column2(升序,这是默认值)排序。
其他回答
ORDER BY column1 DESC, column2
当两行或多行的column1字段相等时,这会先按column1(降序)排序,然后按column2(升序,这是默认值)排序。
SELECT *
FROM mytable
ORDER BY
column1 DESC, column2 ASC
通过DEPTNO ASC、JOB DESC从EMP订单中选择*;
您可以在多个条件下使用多个排序,
ORDER BY
(CASE
WHEN @AlphabetBy = 2 THEN [Drug Name]
END) ASC,
CASE
WHEN @TopBy = 1 THEN [Rx Count]
WHEN @TopBy = 2 THEN [Cost]
WHEN @TopBy = 3 THEN [Revenue]
END DESC
您还可以根据希望排序的每一列中的字符数进行排序或排序。下面显示的是一个示例,它按照名字的前三个字符和城镇名称的后两个字符进行排序。
SELECT *
FROM table_name
ORDER BY LEFT(FirstName, 3) ASC, LEFT(Town, 2);
推荐文章
- 在SQL server查询中将NULL替换为0
- 在SQL中修改表的模式名
- 如何在SQL Server 2005的一条语句中更新两个表?
- 如何创建临时表与SELECT * INTO tempTable从CTE查询
- 用于查找计数为>的记录的SQL查询
- “从Table1左连接Table2”和“从Table2右连接Table1”可以互换吗?
- 在SQL Server的选择语句中使用带TOP的变量,而不是动态的
- 自然连接和内部连接的区别
- MySQL现在()+1天
- 在SQL中转换月号到月名函数
- 改变一个varchar列的最大长度?
- 外键约束:何时使用ON UPDATE和ON DELETE
- 暂时关闭约束(MS SQL)
- WHERE子句中的IF子句
- Postgresql列表和排序表的大小