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中文网其他相关文章!