MySQL按多列组合排序(不按order1 asc,field2 asc排序)

时间:2009-12-01 15:12:55

标签: sql mysql 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

我需要的是获取按最新时间戳排序的id列表(忽略它是在t​​ime1,time2还是time3)。 通过time1 desc,time2 desc,time3 desc 执行命令给了我一个错误的列表,因为它首先对所有time1字段进行排序,然后对第二个字段进行排序等等...

预期结果是id列表。

可以在一个查询中在MySQL中完成吗?感谢

1 个答案:

答案 0 :(得分:13)

SELECT  *
FROM    mytable
ORDER BY
        GREATEST(
        COALESCE(time1, 0),
        COALESCE(time2, 0),
        COALESCE(time3, 0)
        ) DESC