mysql分段排序

需求:

一个活动表,记录有开始时间字段start_time,结束时间字段end_time

需要分页获取全部字段,总体上:

  • 1.正在进行的活动排在最前部分(start_time < now < end_time)

这部分内部,按结束时间升叙,也就是即将结束的活动在前面。

  • 2.即将开始的活动排在中间部分(now < start_time);

这部分内部,按开始时间升序,也就是即将开始的活动在前面。

  • 3.已经过期的活动在最后部分(end_time < now)。

这部分内部,按结束时间降序,也就是最近结束的活动在前面。

分析:

根据条件,将(开始时间,结束时间)映射到一个整数序列,然后根据这个序列排序。

我找到的映射是这样的:

首先确认一个“很大的数”Big。由于数据库的时间范围在1970-01-01 ~ 2038-01-19之间,值小于pow(2, 31),所以我确定的“很大的数”是Big=pow(2, 40);

映射

f(start_time, end_time)

{

    if (start_time < now < end_time) 

    {

        return  end_time;

    }

    else if (now < start_time)

    {

        return start_time + pow(2, 40);

    }

    else if (end_time < now)

    {

        return (-1)*end_time + pow(2,41);

    }

}

自己证明:end_time  <  start_time + pow(2, 40)  <  (-1)*end_time + pow(2,41)

然后,写出的sql语句是:

    SELECT id, start_time, end_time FROM lj_activity WHERE STATUS = 0 ORDER BY  
        IF (UNIX_TIMESTAMP(start_time)<=UNIX_TIMESTAMP(NOW()) AND UNIX_TIMESTAMP(NOW())<UNIX_TIMESTAMP(end_time),  
            UNIX_TIMESTAMP(end_time),  
            IF(UNIX_TIMESTAMP(NOW())<UNIX_TIMESTAMP(start_time),  
                UNIX_TIMESTAMP(start_time)+POW(2,40),  
                UNIX_TIMESTAMP(end_time)*(-1)+POW(2,41)  
            )  
        );  

转发来自:http://blog.csdn.net/longerandlonger/article/details/8137544

manner tips for juniors
quick weight loss Top 6 Shoe Styles To Wear With You On Your Florida Vacation

5 how to find any bohemian style
christina aguilera weight lossSchoolyard Crowd Foments against White
youjizz
此条目发表在 数据库研究 分类目录,贴了 标签。将固定链接加入收藏夹。

评论功能已关闭。