首頁 >資料庫 >mysql教程 >如何使用條件排序基於多個時間戳列對 MySQL 行進行排序?

如何使用條件排序基於多個時間戳列對 MySQL 行進行排序?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-11-16 02:37:03993瀏覽

How to Order MySQL Rows Based on Multiple Timestamp Columns with Conditional Sorting?

MySQL ORDER BY CASE 語句問題:對多個時間戳列進行排序

在MySQL 中,ORDER BY 子句通常用於對以下結果進行排序基於特定列的查詢。然而,在處理需要有條件排序的多個欄位時,會出現一個常見的挑戰。

考慮以下場景:您有一個具有如下結構的資料庫表:

-------------------------------------------------------------------
| id_one | id_two | timestamp_one | timestamp_two |
-------------------------------------------------------------------
| 27     | 35     |    9:30      |     NULL     |
-------------------------------------------------------------------
| 35     | 27     |     NULL     |    9:35      |
-------------------------------------------------------------------
| 27     | 35     |    9:34      |     NULL     |
-------------------------------------------------------------------
| 35     | 27     |     NULL     |    9:33      |
-------------------------------------------------------------------

目標是檢索所有四行,並在考慮特定條件的同時按timestamp_one 和timestamp_two 對它們進行排序。具體來說,如果 id_one 等於 27,則應按 timestamp_one 對行進行排序;否則,如果 id_two 等於 27,則應按 timestamp_two 排序。

為了實現此目的,許多嘗試在 ORDER BY 子句中使用 CASE語句,例如:

SELECT * 
FROM tablename 
WHERE id_one=27 OR id_two=27 
ORDER BY 
  CASE WHEN id_one=27 THEN timestamp_one END DESC, 
  CASE WHEN id_two=27 THEN timestamp_two END DESC

While這種方法為各個行產生所需的排序,它無法將兩個時間戳列組合成統一的排序,因為它們不被視為單一行

解:

要依照需要對行進行排序,我們可以在ORDER BY 子句中使用CASE語句的修改版本:

SELECT id_one, id_two, timestamp_one, timestamp_two      
FROM tablename 
WHERE id_one = 27 
    OR id_two = 27 
ORDER BY 
    CASE 
        WHEN id_one=27 THEN timestamp_one 
        WHEN id_two=27 THEN timestamp_two 
    END DESC 

此修改將 timestamp_one 和 timestamp_two 視為單一實體,並相應地對行進行排序。 CASE 語句根據 WHERE 子句中指定的條件為兩個時間戳列指定降序排列,並確保行作為整體排序。

以上是如何使用條件排序基於多個時間戳列對 MySQL 行進行排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn