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


当前回答

TRY

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

其他回答

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

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 

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

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

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

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

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

ORDER BY column1 DESC, column2

当两行或多行的column1字段相等时,这会先按column1(降序)排序,然后按column2(升序,这是默认值)排序。

TRY

'select * FROM users ORDER BY id DESC, name ASC, age DESC 
SELECT  *
FROM    mytable
ORDER BY
        column1 DESC, column2 ASC