SQL 多列排序

Posted

技术标签:

【中文标题】SQL 多列排序【英文标题】:SQL multiple column ordering 【发布时间】:2010-01-12 18:02:09 【问题描述】:

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

【问题讨论】:

这是“谷歌搜索”的第一个结果。至少是当我用谷歌搜索“两列的 sql 排序”时。它比等效的官方文档页面更具可读性,在我将查询更改为“mysql 'order by'”之前,它甚至没有出现在我的第一页结果中 鉴于 SO 问题经常出现在 Google 上,我总是觉得人们用它来回答很糟糕。所以要么在这里回答或不回答,我不明白为什么引导网站流量是一件好事 【参考方案1】:
ORDER BY column1 DESC, column2

这将首先按column1(降序)对所有内容进行排序,然后在两行或多行的column1 字段相等时按column2(升序,这是默认值)对所有内容进行排序。

【讨论】:

这里如何订购 column1 或 column2? @PoliDev,它首先按 column1 以 DESCending 顺序排序,然后按 column2(按 ASCending 顺序) 为清楚起见,只要两行的column1 字段相等,这将首先按column1 对所有内容进行排序,然后按column2 对所有内容进行排序。 它适用于任意数量的表达式(只是列),直到 RDBMS 的限制。 @NickBenes ...或者您可以说:它按column2 排序,然后按column1 执行STABLE 排序。这对于知道什么是稳定排序的人来说更清楚。【参考方案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

【讨论】:

这个答案是对非常有用且简短接受的答案的一个很好的补充。 这是一个很好的例子,很多人认为如何一次对 2 列进行排序,即使您将 2 列用于订单查询,实际上也不会发生这种情况 当我们用三列排序并且第一列排序顺序相同而其余一切都不同时,它提供了相同的结果。例如::1.Firstname asc, Lastname desc, yearOfBirst asc and 2.Firstname asc, Lastname desc, yearOfBirst desc 有什么办法可以克服这个问题吗? @ParameshKorrakuti:这是预期的结果。仅当存在具有不同 YearOfBirth 的重复 FirstName, LastName 条目时,您示例中的结果排序才会有所不同 谢谢你的例子,它让像我这样的人明白了。【参考方案3】:
SELECT  *
FROM    mytable
ORDER BY
        column1 DESC, column2 ASC

【讨论】:

【参考方案4】:

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

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

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

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

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

【讨论】:

也插入此数据(g, 10),(g,12)。然后,运行你的 order-by 查询,你会得到第二列 ASC order(这意味着 g-10,g-11,g-12)【参考方案5】:

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

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 

【讨论】:

如果我在“ORDER BY”中使用“CASE”,索引是否有效?【参考方案6】:
SELECT id,  
  first_name,
  last_name,
  salary
FROM employee
ORDER BY salary DESC, last_name; 

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

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

【讨论】:

【参考方案7】:

您还可以按您希望排序的每列中的字符数进行排序。下面显示的示例按名字的前三个字符和城镇名称的后两个字符排序。

SELECT *
FROM table_name
ORDER BY LEFT(FirstName, 3) ASC, LEFT(Town, 2);

【讨论】:

以上是关于SQL 多列排序的主要内容,如果未能解决你的问题,请参考以下文章

如何在 SQL 中按多列分组并按日期排序?

SQL按多列以不同顺序排序后选择奇数行

具有不同排序方向的多列上的Sql server聚集索引

SQL Server 中多列的动态排序

在 PyQt 模型中按多列排序

按多列排序