• 学习关于时间在sql里面的对比,用if语句(这个有点特别) 简单


    需求:假如当前时间是大于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值,这样未开始的值记录排在了已开始记录之后了。

  • 相关阅读:
    //设N是一个四位数,它的9倍恰好是其反序数(例如:1234 的反序数是4321),求N的值。
    安装oracle后,电脑变卡变慢的解决办法
    JSONP
    vue-resource发起get、post、jsonp请求
    Vue实例的生命周期
    自定义全局指令让文本框获取焦点
    自定义全局按键修饰符
    es2017 提供的针对字符串填充的函数:padStart、padEnd
    自定义私有过滤器
    fiddler教程
  • 原文地址:https://www.cnblogs.com/xiangxiaodong/p/2828609.html
Copyright © 2020-2023  润新知