select * from (
select
tablename_tmp.*,
@rownum:=@rownum+1 ,
if(time >=DATE_FORMAT(now(),'%Y-%m-%d %H:00') ,@rank:=@rank+1,@rank:=0) as rank
from (
select * from tablename order by time desc
)
tablename_tmp ,
(select @rownum :=0 , @ptime := null ,@rank:=0) a
) a
order by rank desc ,time desc
---------------------------------------方法2
select * from tablename order by
(case when DATE_FORMAT(time ,'%k')=0 then 24 when DATE_FORMAT(time ,'%k')*1>=DATE_FORMAT(now(),'%k')*1 then DATE_FORMAT(time ,'%k') else 25 end) ,time desc
题主测试一下?你这里的24点应该是第二天的00:00:00 。你这样排有什么用处?
这样就可以了
$orderbysql=" ORDER BY stick DESC , FROM_UNIXTIME(`refreshtime`,'%Y-%m-%d') DESC , id DESC"select * from (select 时间1 from 表1union all
select 时间2 from 表2
…………
union all
select 时间N from 表N) as 表名
我只是简单写了一下,查询的是一个字段,要是你的表的字段是完全一样的话,就可以用 * 代替,要是不一样的话,可以手动按照顺序写对应的字段,要是字段个数不一样多的话,可以用''代替没有的字段,不知到我说的能否明白?
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)