0

这个问题与我之前的问题有关 - MySQL 查询以显示当前日期在顶部的记录,其他按降序排列。我现在使用的查询是,

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但过期日期列在今天日期之后。我需要在今天的日期之后列出未来的日期,之后只列出过期的日期。如何实施?

需要帮忙。提前致谢

4

2 回答 2

3

ORDER BY 将按从左到右的顺序处理每个条件。因此,如果您需要的排序类似于“任何具有今天日期的条目,然后是将来按日期升序排列的任何条目,然后是按日期升序排列的其他条目”,您可以执行以下操作

ORDER BY (sale_ends=CURDATE()) DESC,(sale_ends>CURDATE()) DESC,sale_ends ASC

前两个被列为 DESC 的原因是,如果为真,则条件将评估为 1,如果为假,则条件将评估为 0。由于您首先需要真实条件,因此您需要按 DESCending 顺序对它们进行排序。

于 2012-04-11T08:03:55.590 回答
1

我可能会误解一些东西,但这不是你要找的吗?

order by sale_ends < curdate(), sale_ends

在这里拉小提琴。

于 2012-04-11T08:20:30.670 回答