SQL多列排序

匆匆过客 提交于 2020-01-06 15:41:25

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

我试图按SQL中不同方向的多个列进行排序。 column1将按降序排序,而column2将按升序排序。

我怎样才能做到这一点?


#1楼

ORDER BY column1 DESC, column2

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


#2楼

SELECT  *
FROM    mytable
ORDER BY
        column1 DESC, column2 ASC

#3楼

其他答案缺少一个具体的示例,因此请按以下步骤进行:

给定以下人员表:

 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

#4楼

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

现在,我通过执行以下命令在这两列中执行“ 订购依据”:

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

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

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


#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 
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!