zoukankan      html  css  js  c++  java
  • mysql 字符串转日期及其他日期转换

    -- 整数转日期
    select DATE_FORMAT(STR_TO_DATE(197001,'%Y%m%d'), '%Y-%m') --1970-01
    
    -- 字符串转日期
    select str_to_date('2019/1/1', '%Y/%m/%d') -- 2019-01-01
    
    SELECT STR_TO_DATE(concat(Cyear,'/',Cmonth,'/',Cday),'%Y/%m/%d') 
    
    SELECT  date_format(DATE_ADD(DATE_FORMAT(CONCAT('2020-03','-01'),'%Y-%m-%d'),INTERVAL -1 month ),'%Y-%m') -- 2020-02 
    
    
    
    select date_format(str_to_date('2019/1', '%Y/%m'),'%Y-%m') -- 2019-01
    
    -- 取昨日
    select DATE_SUB(20180802,INTERVAL 1 day); -- 2018-08-01
    -- 取上月
    select DATE_SUB(20180802,INTERVAL 1 month); -- 2018-07-02
     
    -- 日期转换 y是年m是月d是日
    select date_format(20180802,'%Y-%m-%d'); -- 2018-08-02
    -- 日期转换 y是年m是月d是日
    select date_format(20180802,'%Y%m'); -- 201808 
     
    -- 字符串转日期
    select STR_TO_DATE(201908,'%Y%m%d'); -- 2019-08-00
    select STR_TO_DATE('2018-10-10 16:47:01:054','%Y-%m-%d %H:%i:%s:%f'); -- 2018-10-10 16:47:01.054000
     
    -- 根据日期求上个月
    select DATE_FORMAT(DATE_SUB(20180801,INTERVAL 1 month),'%Y%m') ; -- 201807
     
    -- 根据日期求上个月 ps:因为date_sub 不支持201908和20190800格式所以需要补充01然后得到上月01再转换格式到月
    select DATE_FORMAT(DATE_SUB(date_format(concat(201808,'01'),'%Y%m%d'),INTERVAL 1 month),'%Y%m') ; -- 201807 
     
    -- 根据日期求上个月简便写法
    select period_add(201908, -1);  -- 201907

    获取当月最后一天
    select last_day(curdate());

    获取本月的第一天
    select date_add(curdate(),interval -day(curdate())+1 day) ;

    获取下个月的第一天
    select date_add(curdate()-day(curdate()) +1 , interval 1 month );

    获取当前月已过了几天
    select day(curdate());

    获取当前月的天数(先加一个月,再减今天是第几天,得到当前月的最后一天,最后求最后一天是几号)
    select day(date_add( date_add(curdate(),interval 1 month),interval -day(curdate()) day ));

    上个月的第一天
    select date_sub(date_sub(date_format(now(),’%y-%m-%d’),interval extract(
    day from now())-1 day),interval 1 month)

    上个月的最后一天:
    select date_sub(date_sub(date_format(now(),’%y-%m-%d’),interval extract(
    day from now()) day),interval 0 month) as date

    这个月的第一天:
    select date_sub(date_sub(date_format(now(),’%y-%m-%d’),interval extract(day from now())-1 day),interval 0 month)

    获取当月最后一天
    select date_sub(date_format(now(),’%y-%m-%d’),interval extract(day from now())-1 day)

      

    作者:鲁班快跑

    出处:https://www.cnblogs.com/zhusf/p/15719706.html

    版权:本文版权归作者和博客园共有

    转载:您可以随意转载、摘录,但请在文章内注明作者和原文链接。

  • 相关阅读:
    测试模式 windows2008 内部版本7601
    移动端UC /QQ 浏览器的部分私有Meta 属性
    正则表达式 正向预查 负向预查
    获取指定元素的某一个样式属性值
    把普通对象转换成json格式的对象
    求平均数-----类数组转换成数组
    轮播图
    倒计时
    JS 预解释相关理解
    ul ol di三者区别
  • 原文地址:https://www.cnblogs.com/zhusf/p/15719706.html
Copyright © 2011-2022 走看看