mysql多条件判断排序

1.有字段 a储存时间,字段b储存状态(有1,2,3,4 4种状态)

现在需要的排序:状态值为1 且 储存时间在24小时内(即 time()-24*60*60 <a) 的数据按照储存时间倒序排在前面,剩余的按照储存时间倒序排在后面,mysql排序语句怎么写?

阅读 6.8k
2 个回答
select * from test_table order by (case when time()-`a`<=24*60*60 and `b` = 1 then 0 else 1 end),`a` desc

大致代码如下

select *,case a WHEN (time()-a)/60/60>24 THEN 0 WHEN (time()-a)/60/60<=24 THEN 1 end as g from tablename where a=1 group by g order by g desc,a desc
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题