这个问题与我之前的问题有关 - MySQL query to show records with current date on top and others as per descending order。我现在使用的查询是,
SELECT b.sales_id,b.category_id,b.sale_starts,b.sale_ends
FROM tbl_sales b WHERE b.active=1
UNION
SELECT b.sales_id,b.category_id,b.sale_starts,b.sale_ends
FROM tbl_sales b INNER JOIN tb_category c ON b.category_id=c.cat_id
WHERE c.cat_keyword LIKE 'a'
ORDER BY IF(sale_ends = DATE(NOW()), 0, 1), sale_ends DESC
,返回的结果如下,
sales_id | category_id |sale_starts | sale_ends
----------|---------------------|------------|--------------
4 | 12 | 2012-04-05 | 2012-04-11 (today's date)
1 | 10 | 2012-03-31 | 2012-04-30
2 | 11 | 2012-03-22 | 2012-04-27
3 | 25 | 2012-03-31 | 2012-04-25
5 | 18 | 2012-04-05 | 2012-04-09
6 | 20 | 2012-02-23 | 2012-02-27
7 | 14 | 2012-02-25 | 2012-02-26
但是现在我遇到了另一个问题,我需要对记录进行排序,如下所示 -
sales_id | category_id |sale_starts | sale_ends
----------|---------------------|------------|--------------
4 | 12 | 2012-04-05 | 2012-04-11 (today's date)
3 | 25 | 2012-03-31 | 2012-04-25
2 | 11 | 2012-03-22 | 2012-04-27
1 | 10 | 2012-03-31 | 2012-04-30
7 | 14 | 2012-02-25 | 2012-02-26 (expired/past dates)
6 | 20 | 2012-02-23 | 2012-02-27
5 | 18 | 2012-04-05 | 2012-04-09
我曾尝试在查询中使用ASC
而不是DESC
,但过期日期会在今天的日期之后列出。我需要在今天的日期之后列出的未来日期,之后只有过期的日期。如何实施?
需要帮助。提前致谢
答案 0 :(得分:3)
ORDER BY将按从左到右的顺序处理每个条件。因此,如果您需要的顺序是“任何具有今天日期的条目,那么将来的任何条目按日期的升序排列,那么其他条目按日期的升序排列”您可以执行类似的操作
ORDER BY (sale_ends=CURDATE()) DESC,(sale_ends>CURDATE()) DESC,sale_ends ASC
前两个被列为DESC的原因是,如果为真,条件将评估为1,如果为假,则评估为零。由于您首先需要真实条件,因此您需要按DESCending顺序对它们进行排序。
答案 1 :(得分:1)