我试图按SQL中不一样方向的多个列进行排序。 column1
将按降序排序,而column2
将按升序排序。 spa
我怎样才能作到这一点? code
ORDER BY column1 DESC, column2
每当两行或更多行的column1
字段相等时,这将首先按column1
(降序)对全部内容进行排序,而后按column2
(升序,这是默认设置)对全部内容进行排序。 排序
SELECT * FROM mytable ORDER BY column1 DESC, column2 ASC
其余答案缺乏一个具体的示例,所以请按如下步骤进行: 图片
给定如下人员表: get
FirstName | LastName | YearOfBirth ---------------------------------------- Thomas | Alva Edison | 1847 Benjamin | Franklin | 1706 Thomas | More | 1478 Thomas | Jefferson | 1826
若是执行如下查询: io
SELECT * FROM People ORDER BY FirstName DESC, YearOfBirth ASC
结果集将以下所示: table
FirstName | LastName | YearOfBirth ---------------------------------------- Thomas | More | 1478 Thomas | Jefferson | 1826 Thomas | Alva Edison | 1847 Benjamin | Franklin | 1706
多列排序取决于两列的相应值:这是个人表格示例,其中两列以字母和数字命名,这两列中的值分别为asc和desc顺序。 ast
如今,我经过执行如下命令在这两列中执行“ 订购依据”: bug
如今再次在这两列中插入新值,其中字母值按ASC顺序排列: im
而且“示例”表中的列以下所示。 如今再次执行相同的操做:
您能够看到第一列中的值按desc顺序排列,而第二列中的值按ASC顺序排列。
您能够在多种条件下使用多种顺序,
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