扫码关注官方订阅号
1.有字段 a储存时间,字段b储存状态(有1,2,3,4 4种状态)
现在需要的排序:状态值为1 且 储存时间在24小时内(即 time()-24*60*60 <a) 的数据按照储存时间倒序排在前面,剩余的按照储存时间倒序排在后面,mysql排序语句怎么写?
time()-24*60*60 <a
认证0级讲师
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
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
大致代码如下