簡體   English   中英

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

[英]MySQL Order by multiple column combined (not order by field1 asc, field2 asc)

這似乎是一個典型的問題,但它有所不同。

我有一個帶有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中完成嗎? 謝謝

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM