我有一个会议表,其中包含以下相关字段:
我想查询事件结束比今天更大的所有会议,命令如下:
我试过了:
(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?,但我的情况完全不同。
答案 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作为要排序的值,具体取决于通知是否在将来