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

最初の2つがDESCとしてリストされている理由は、条件がtrueの場合は1、falseの場合は0と評価されるためです。最初に真の条件が必要なので、降順で並べ替える必要があります。

于 2012-04-11T08:03:55.590 に答える
1

私は何かを誤解しているかもしれませんが、これはあなたが探しているものではありませんか?

order by sale_ends < curdate(), sale_ends

ここでフィドル。

于 2012-04-11T08:20:30.670 に答える