MySQL中的条件排序

时间:2014-06-30 11:27:51

标签: mysql sorting sql-order-by

我有一个会议表,其中包含以下相关字段:

  1. 会议名称(文字)
  2. 提交截止日期(日期)
  3. 通知日期(日期)
  4. 活动开始(日期)
  5. 活动结束(日期)
  6. 我想查询事件结束比今天更大的所有会议,命令如下:

    1. 首先,通知在将来的所有会议;通过通知日期订购这些。
    2. 然后,所有通知都在过去的会议;通过活动开始订购这些。
    3. 我试过了:

      (SELECT * FROM conferences
       WHERE ev_end >= '2014-06-30'
       AND notification >= '2014-06-30'
       ORDER BY notification ASC)
      UNION
      (SELECT * FROM conferences
       WHERE ev_end >= '2014-06-30'
       AND notification < '2014-06-30'
       ORDER BY ev_start ASC);
      

      但它不起作用,排序不正确。事实上,我根本没有看到任何排序:当我省略两个ORDER BY子句时,结果以完全相同的方式排序(即,看起来是随机的)。

      是否可以通过一个 SQL查询实现此目的?或者我是否必须进行两次单独的查询?

      我知道这个问题:Conditional sorting in MySQL?,但我的情况完全不同。

3 个答案:

答案 0 :(得分:3)

您可以通过将所有逻辑放在order by子句中来执行此操作:

select *
from conferences
where ev_end >= '2014-06-30' 
order by (notification >= '2014-06-30') desc,
         (case when notification >= '2014-06-30' then notification end) asc,
         (case when notification < '2014-06-30' then ev_start end) asc;

请注意,union显式不保证结果集的顺序。如果您希望以特定顺序设置结果集,那么您需要在查询的最外部分中使用order by

答案 1 :(得分:1)

SELECT *
FROM conferences
WHERE ...
ORDER BY notification < '2014-06-30', 
         IF(notification < '2014-06-30', ev_start, notification)

答案 2 :(得分:1)

SELECT * 
FROM conferences
WHERE ev_end >= '2014-06-30'
ORDER BY IF(notification >= '2014-06-30', notification, ev_start) ASC

IF用于返回通知或ev_start作为要排序的值,具体取决于通知是否在将来