zoukankan      html  css  js  c++  java
  • sql 语句系列(闰年)[八百章之第十九章]

    前言

    判断闰年还是挺有用的。

    mysql

    select DAY(LAST_DAY(DATE_ADD(CURRENT_DATE,INTERVAL -DAYOFYEAR(CURRENT_DATE)+1+31 DAY))) as dy
    FROM T1
    

    这个看起来有一点点复杂,其实拆开了还是很简单的。
    CURRENT_DATE 获取当前日期。

    DATE_ADD(CURRENT_DATE,INTERVAL -DAYOFYEAR(CURRENT_DATE)+1+31 DAY)
    

    当前的日期,减去了从1月1号经历的天数然后加1,这个获得的就是1月1号。因为1月有31天,所以加上31,那么就是今年的2月1号。

    LAST_DAY 是获取该月的最后一天。所以就能够得出2月最后一天的日期了。

    sql server

    with x(dy,mth) as
    (
    select dy,MONTH(dy)
    from(
    select dateadd(MM,1,(getdate()-datepart(dy,getdate()))+1) dy
    from T1) tmp1
    union all
    select dateadd(dd,1,dy),mth
    from x
    where MONTH(dateadd(dd,1,dy))=mth
    )
    select MAX(DAY(dy))
    from x
    

    这么一看有点复杂,原理是一样的。

    select dateadd(MM,1,(getdate()-datepart(dy,getdate()))+1) dy
    from T1
    

    获取2月第一天,第一步和mysql是一致的。

    然后就是递归2月的每一天,得出最后一天是28还是29。

  • 相关阅读:
    postman接口测试工具
    fiddler如何做弱网测试
    支付的测试点
    公交卡测试点
    http的请求方式及http和https的区别
    百度输入框测试点
    ADB常用命令
    Python 操作注册表
    App测试流程及测试点
    python3.7 打包成exe的一种方法 pyinstaller
  • 原文地址:https://www.cnblogs.com/aoximin/p/12670450.html
Copyright © 2011-2022 走看看