需求:假如当前时间是大于starttime且小于endtime的则按starttime倒序排列显示一条记录;假如当前时间小于starttime且小于endtime则按starttime正序排列显示一条记录。要在一次sql查询中完成。
====这个是论坛里面的,人家给出答案了,我只是学习的.算做个学习笔记,也许以后会用到。怕脑子坏了
SELECT FROM_UNIXTIME( starttime, '%Y年%m月%d日 %H时%i分%s秒' ) AS starttime, FROM_UNIXTIME( endtime, '%Y年%m月%d日 %H时%i分%s秒' ) , if( starttime < UNIX_TIMESTAMP( ) , starttime - UNIX_TIMESTAMP( ) , (
starttime - UNIX_TIMESTAMP( ) ) +20000000
) AS t
FROM test
WHERE endtime > UNIX_TIMESTAMP( )
ORDER BY t ASC
LIMIT 0 , 30
if()函数就是实现这个的关键。
IF(expr1,expr2,expr3)
如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。
为true
执行 starttime - UNIX_TIMESTAMP() 按得到的值asc排序这样就得到了“距离现在最近的starttime,也就是刚刚已经开始的”记录列表
为false
执行 (starttime - UNIX_TIMESTAMP())+20000000
starttime - UNIX_TIMESTAMP()这样得到了 “starttime距离现在最近的,也就是马上将要到来的starttime”记录列表;由于 “未开始记录的”starttime - UNIX_TIMESTAMP() 得到的值可能小于“已开始记录的”starttime - UNIX_TIMESTAMP() 的值,这种情况下排序就混乱了,所以要加上一个很大的值20000000避免这种情况,这样就能保证未开始记录的starttime永远大于已开始记录的starttime值,这样未开始的值记录排在了已开始记录之后了。