做图网站地图,如何做婚恋网站,免费域名cn,国内的足彩网站怎么做的需求#xff1a;假如当前时间是大于starttime且小于endtime的则按starttime倒序排列显示一条记录#xff1b;假如当前时间小于starttime且小于endtime则按starttime正序排列显示一条记录。要在一次sql查询中完成。 这个是论坛里面的#xff0c;人家给出答案了#xff0c;我…需求假如当前时间是大于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值这样未开始的值记录排在了已开始记录之后了。 转载于:https://www.cnblogs.com/xiangxiaodong/archive/2012/12/21/2828609.html