mysql 字符串转日期及其他日期转换

复制代码
-- 字符串转日期
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
复制代码

 

posted @   瓶子xf  阅读(4642)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
历史上的今天:
2019-03-27 Excel好用的技巧
2019-03-27 Excel插件之连接数据数据库秒数处理,办公轻松化
点击右上角即可分享
微信分享提示