加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2020-12-11 23:44:52 所属栏目:MySql教程 来源:网络整理
导读:这似乎是一个典型的问题,但它有所不同. 我有一个带有id和3个时间戳字段的表(简单地说).最初所有3个字段都为空,并且它们填充了值.行的示例是: id time1 time2 time31 1259625661 1259643563 null2 null 1259621231 null3 1259625889 null 12596445114 null 1

这似乎是一个典型的问题,但它有所不同.

我有一个带有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,COALESCE(time3,0)
        ) DESC

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读