如何在SQL中按多个列和不同方向进行排序。column1将按降序排序,column2将按升序排序。
当前回答
通过DEPTNO ASC、JOB DESC从EMP订单中选择*;
其他回答
TRY
'select * FROM users ORDER BY id DESC, name ASC, age DESC
您还可以根据希望排序的每一列中的字符数进行排序或排序。下面显示的是一个示例,它按照名字的前三个字符和城镇名称的后两个字符进行排序。
SELECT *
FROM table_name
ORDER BY LEFT(FirstName, 3) ASC, LEFT(Town, 2);
其他答案缺少一个具体的例子,因此如下:
给定以下人员表:
FirstName | LastName | YearOfBirth
----------------------------------------
Thomas | Alva Edison | 1847
Benjamin | Franklin | 1706
Thomas | More | 1478
Thomas | Jefferson | 1826
如果执行以下查询:
SELECT * FROM People ORDER BY FirstName DESC, YearOfBirth ASC
结果集将如下所示:
FirstName | LastName | YearOfBirth
----------------------------------------
Thomas | More | 1478
Thomas | Jefferson | 1826
Thomas | Alva Edison | 1847
Benjamin | Franklin | 1706
SELECT *
FROM mytable
ORDER BY
column1 DESC, column2 ASC
SELECT id,
first_name,
last_name,
salary
FROM employee
ORDER BY salary DESC, last_name;
如果您想从表中选择记录,但希望看到它们按照两列进行排序,可以使用ORDERBY。
在ORDERBY关键字之后,添加要首先对记录排序的列的名称(在我们的示例中为salary)。然后,在逗号后添加第二列(在我们的示例中为last_name)。您可以分别修改每列的排序顺序(升序或降序)。如果要使用升序(从低到高),可以使用ASC关键字;但是,这个关键字是可选的,因为当没有指定时,这是默认顺序。如果要使用降序,请将DESC关键字放在适当的列之后(在本例中,我们对薪资列使用了降序)。
推荐文章
- SQL OVER()子句-它什么时候有用,为什么有用?
- 如果字段在MySQL中为空,则返回0
- 我如何使用ROW_NUMBER()?
- SQL或者TSQL是图灵完备的吗?
- 如何检查表上持有哪些锁
- 对于PostgreSQL表来说,多大才算太大?
- 在MySQL中检测值是否为number
- MySQL中两个日期之间的差异
- 使用SQL查询查找最近的纬度/经度
- 将一列的多个结果行连接为一列,按另一列分组
- 检查MySQL表是否存在而不使用“select from”语法?
- 在PostgreSQL中快速发现表的行数
- 更改varchar列的大小为较低的长度
- 从表中选择1是什么意思?
- SQL Server中User和Login的区别