首页 >数据库 >mysql教程 >如何使用条件排序基于多个时间戳列对 MySQL 行进行排序?

如何使用条件排序基于多个时间戳列对 MySQL 行进行排序?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-16 02:37:03972浏览

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