如何在SQL中按多个列和不同方向进行排序。column1将按降序排序,column2将按升序排序。
当前回答
您还可以根据希望排序的每一列中的字符数进行排序或排序。下面显示的是一个示例,它按照名字的前三个字符和城镇名称的后两个字符进行排序。
SELECT *
FROM table_name
ORDER BY LEFT(FirstName, 3) ASC, LEFT(Town, 2);
其他回答
您还可以根据希望排序的每一列中的字符数进行排序或排序。下面显示的是一个示例,它按照名字的前三个字符和城镇名称的后两个字符进行排序。
SELECT *
FROM table_name
ORDER BY LEFT(FirstName, 3) ASC, LEFT(Town, 2);
SELECT id,
first_name,
last_name,
salary
FROM employee
ORDER BY salary DESC, last_name;
如果您想从表中选择记录,但希望看到它们按照两列进行排序,可以使用ORDERBY。
在ORDERBY关键字之后,添加要首先对记录排序的列的名称(在我们的示例中为salary)。然后,在逗号后添加第二列(在我们的示例中为last_name)。您可以分别修改每列的排序顺序(升序或降序)。如果要使用升序(从低到高),可以使用ASC关键字;但是,这个关键字是可选的,因为当没有指定时,这是默认顺序。如果要使用降序,请将DESC关键字放在适当的列之后(在本例中,我们对薪资列使用了降序)。
您可以在多个条件下使用多个排序,
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
通过DEPTNO ASC、JOB DESC从EMP订单中选择*;
ORDER BY column1 DESC, column2
当两行或多行的column1字段相等时,这会先按column1(降序)排序,然后按column2(升序,这是默认值)排序。
推荐文章
- 如何结合日期从一个字段与时间从另一个字段- MS SQL Server
- 如何在不知道其名称的情况下删除SQL默认约束?
- SQL语法区分大小写吗?
- MySQL工作台:如何保持连接活动
- 左连接与Where子句
- 如何使用实体框架只更新一个字段?
- 在表变量上创建索引
- 为什么历史上人们使用255而不是256作为数据库字段大小?
- 如何选择记录从过去24小时使用SQL?
- 如何为查询返回的每一行执行存储过程一次?
- 按IN值列表排序
- 如何使用SQL Server 2008做多个CASE WHEN条件?
- 计数在VARCHAR字段中字符串的出现次数?
- 如何选择多行填充常量?
- 修改一个MySQL列为AUTO_INCREMENT