SQL多列排序

时间:2010-01-12 18:02:10

标签: sql sql-order-by

我正在尝试按SQL在多个列中进行排序,并且方向不同。 column1将按降序排序,并column2升序。

我该怎么做?

6 个答案:

答案 0 :(得分:902)

ORDER BY column1 DESC, column2

只要两行或更多行的column1字段相等,这将按column2(降序)排序,然后按column1(升序,这是默认值)排序。< / p>

答案 1 :(得分:316)

其他答案缺乏一个具体的例子,所以在这里:

鉴于以下表:

 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

答案 2 :(得分:129)

SELECT  *
FROM    mytable
ORDER BY
        column1 DESC, column2 ASC

答案 3 :(得分:13)

多列排序取决于列的相应值: 这是我的表示例,其中有两列以Alphabets和Numbers命名,这两列中的值是 asc desc 订单。

enter image description here

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

enter image description here

现在我再次在这两列中插入新值,其中Alphabet值在 ASC 顺序中:

enter image description here

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

enter image description here

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

答案 4 :(得分:4)

您可以在多个条件下使用多个排序,

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 

答案 5 :(得分:0)

SELECT id,  
  first_name,
  last_name,
  salary
FROM employee
ORDER BY salary DESC, last_name; 

如果您想从表中选择记录但希望看到它们根据两列排序,您可以使用 ORDER BY 来实现。此子句位于 SQL 查询的末尾。

在 ORDER BY 关键字之后,添加您希望首先按其对记录进行排序的列的名称(在我们的示例中,salary)。然后,在逗号之后,添加第二列(在我们的示例中,last_name)。您可以分别修改每列的排序顺序(升序或降序)。如果要使用升序(从低到高),可以使用 ASC 关键字;但是,this 关键字是可选的,因为当没有指定时,这是默认顺序。如果要使用降序,请将 DESC 关键字放在适当的列之后(在示例中,我们对工资列使用降序)。