如何在SQL中按多个列和不同方向进行排序。column1将按降序排序,column2将按升序排序。


当前回答

多列排序取决于两列的对应值:这是我的表示例,其中有两列用字母和数字命名,这两列中的值是asc和desc顺序。

现在我通过执行以下命令在这两列中执行Order By:

现在我再次在这两列中插入新值,其中字母值按ASC顺序排列:

示例表中的列如下所示。现在再次执行相同的操作:

您可以看到第一列中的值按降序排列,但第二列不按ASC顺序排列。

其他回答

其他答案缺少一个具体的例子,因此如下:

给定以下人员表:

 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 table_name
ORDER BY LEFT(FirstName, 3) ASC, LEFT(Town, 2);

TRY

'select * FROM users ORDER BY id DESC, name ASC, age DESC 

多列排序取决于两列的对应值:这是我的表示例,其中有两列用字母和数字命名,这两列中的值是asc和desc顺序。

现在我通过执行以下命令在这两列中执行Order By:

现在我再次在这两列中插入新值,其中字母值按ASC顺序排列:

示例表中的列如下所示。现在再次执行相同的操作:

您可以看到第一列中的值按降序排列,但第二列不按ASC顺序排列。

SELECT  *
FROM    mytable
ORDER BY
        column1 DESC, column2 ASC