Fer*_*Gil 5 mysql sql sql-order-by
这似乎是一个典型的问题,但它有所不同.
我有一个带有id和3个时间戳字段的表(简单地说).最初所有3个字段都为空,并且它们填充了值.行的示例是:
id time1 time2 time3
1 1259625661 1259643563 null
2 null 1259621231 null
3 1259625889 null 1259644511
4 null 1259621231 null
5 null null 1259644511
6 null 1259621231 null
7 1259625889 null null
Run Code Online (Sandbox Code Playgroud)
我需要的是获取按最新时间戳排序的id列表(忽略它是在time1,time2还是time3).通过time1 desc,time2 desc,time3 desc执行一个命令给了我一个错误的列表,因为它首先排序所有time1字段,然后是第二个,等等...
预期结果是id的列表.
那可以在一个查询中在MySQL中完成吗?谢谢
Qua*_*noi 13
SELECT *
FROM mytable
ORDER BY
GREATEST(
COALESCE(time1, 0),
COALESCE(time2, 0),
COALESCE(time3, 0)
) DESC
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3782 次 |
| 最近记录: |