gpt4 book ai didi

php - MySQL 查询排序记录 ORDER BY

转载 作者:太空宇宙 更新时间:2023-11-03 11:08:37 27 4
gpt4 key购买 nike

这个问题与我之前的问题有关 - 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 但过期日期列在今天的日期之后。我需要在今天的日期之后列出 future 的日期,之后只列出过期日期。如何实现?

需要帮助。提前致谢

最佳答案

ORDER BY 会按照从左到右的顺序处理每个条件。因此,如果您需要的顺序类似于“今天日期的任何条目,然后是 future 按日期升序排列的任何条目,然后是其他按日期升序排列的条目”,您可以这样做

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

前两个被列为 DESC 的原因是如果条件为真,条件将计算为 1,如果为假,条件将计算为零。由于您首先需要真实条件,因此您需要按降序排列它们。

关于php - MySQL 查询排序记录 ORDER BY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10102042/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com