【问题标题】:MySQL ORDER BY 2 Columns with conditionMySQL ORDER BY 2 列有条件
【发布时间】:2020-06-03 20:35:34
【问题描述】:

我有下表,我们称之为buildings

building_code  |  city  |  phone
1              |  A     |  +1 212 444 555
2              |  B     |  +2 333 444 555
3              |  C     |  +3 222 234 122
4              |  A     |  +1 212 555 444

所以每个城市都有一些建筑物。我现在要做的是从建筑物中选择城市和电话号码。但是,我想按升序对城市进行排序,如果一个城市有多个建筑物(例如 A),那么我还想按降序对电话号码进行排序。

最终结果是

city  |  phone
A     |  +1 212 555 444
A     |  +1 212 444 555
B     |  +2 333 444 555
C     |  +3 222 234 122

所以我尝试的查询是SELECT city, phone FROM buildings ORDER BY city ASC 这可以按升序对城市名称进行排序。但是,我不确定如何按降序订购手机。

我尝试了SELECT city, phone FROM buildings ORDER BY city ASC, IF(COUNT(city) > 1, phone, '') DESC;,但它给了我一个错误。

【问题讨论】:

    标签: mysql sql


    【解决方案1】:
    SELECT city, phone FROM buildings ORDER BY city ASC, phone DESC
    

    就这么简单。看到它在现场工作here

    【讨论】:

    • 哈哈,我不敢相信。我在这里真的把事情复杂化了。你能解释一下背后的逻辑吗?
    • phone DESC 不需要条件,因为无论有 0 行、1 行还是更多行,它的行为都是一样的。
    • @nTuply 你能解释一下背后的逻辑吗? ORDER BY city ASC, phone DESC 意思是:按城市升序排序,如果一堆记录有同一个城市,则在里面排序此组(仅)通过电话按降序排列。
    • 啊,其他人解释的比较快。谢谢大家。
    • 谢谢大家:)
    【解决方案2】:

    试试这个

    SELECT city, phone FROM buildings ORDER BY city ASC, phone DESC;
    

    【讨论】:

      猜你喜欢
      • 2014-06-19
      • 2012-05-24
      • 1970-01-01
      • 1970-01-01
      • 2011-12-06
      • 2017-04-17
      • 2014-10-03
      • 2018-11-28
      • 2014-05-28
      相关资源
      最近更新 更多