MYSQL的date_format以及STR_TO_DATE_MySQL

WBOY
풀어 주다: 2016-06-01 13:32:04
원래의
1314명이 탐색했습니다.

bitsCN.com

MYSQL的date_format以及STR_TO_DATE

 

最近做项目,好好玩了下MYSQL的日期转换函数,过程如下:

 

拿当前年份:SELECT DATE_FORMAT(CURDATE(),'%Y年');    输出:2013年拿当前年份中第几月:SELECT DATE_FORMAT(CURDATE(),'%Y年第%m月');     输出:2013年第07月拿当前年份中第几周:SELECT DATE_FORMAT(CURDATE(),'%Y年第%u周');         输出:2013年第28周
로그인 후 복사
로그인 후 복사

OK,全部拿到,是不是很爽,更爽的在下面:

拿到了后,想了一下是否可以转回来呢? 立马动手!

将2013年转成时间对象:

SELECT STR_TO_DATE(year(CURDATE()),"%Y")=STR_TO_DATE('2013年',"%Y年");   输出: 1  
로그인 후 복사
로그인 후 복사

看来有戏!继续将2013年第07月转时间对象:

SELECT date_format(CURDATE(),"%Y-%m")=date_format(STR_TO_DATE('2013年第07月',"%Y年第%m月"),"%Y-%m");    输出: 1
로그인 후 복사
로그인 후 복사

完全没问题! 再继续将2013年第28周转时间对象:

SELECT date_format(CURDATE(),"%Y-%u")=date_format(STR_TO_DATE('2013年第28周',"%Y年第%u周"),"%Y-%u");      输出:0   
로그인 후 복사

WHY???? 继续找原因,发现个神奇的现象:

SELECT date_format(STR_TO_DATE('2013年第28周',"%Y年第%u周"),"%Y-%u"); 
로그인 후 복사
로그인 후 복사

输出的结果居然是:2013-613566753

问度娘完全没有参考的东西可看。头痛了半天,最后想到如下解决办法:

仍旧是以2013年第28周来比较:

SELECT date_format(CURDATE(),'%Y') = date_format(STR_TO_DATE('2013年第28周',"%Y年"),'%Y') and date_format(CURDATE(),'%u') = (select SUBSTR('2013年第28周' FROM 7 FOR 2)) ;     输出:1MYSQL的date_format以及STR_TO_DATE
로그인 후 복사

最近做项目,好好玩了下MYSQL的日期转换函数,过程如下:

拿当前年份:SELECT DATE_FORMAT(CURDATE(),'%Y年');    输出:2013年拿当前年份中第几月:SELECT DATE_FORMAT(CURDATE(),'%Y年第%m月');     输出:2013年第07月拿当前年份中第几周:SELECT DATE_FORMAT(CURDATE(),'%Y年第%u周');         输出:2013年第28周
로그인 후 복사
로그인 후 복사

OK,全部拿到,是不是很爽,更爽的在下面:(呃,大家可以邪恶一下!)

拿到了后,想了一下是否可以转回来呢? 立马动手!

将2013年转成时间对象:

SELECT STR_TO_DATE(year(CURDATE()),"%Y")=STR_TO_DATE('2013年',"%Y年");   输出: 1  
로그인 후 복사
로그인 후 복사

看来有戏!继续将2013年第07月转时间对象:

SELECT date_format(CURDATE(),"%Y-%m")=date_format(STR_TO_DATE('2013年第07月',"%Y年第%m月"),"%Y-%m");    输出: 1
로그인 후 복사
로그인 후 복사

完全没问题! 再继续将2013年第28周转时间对象:

SELECT date_format(CURDATE(),"%Y-%u")=date_format(STR_TO_DATE('2013年第28周',"%Y年第%u周"),"%Y-%u");      输出:0    
로그인 후 복사

WHY???? 继续找原因,发现个神奇的现象:

SELECT date_format(STR_TO_DATE('2013年第28周',"%Y年第%u周"),"%Y-%u"); 
로그인 후 복사
로그인 후 복사

输出的结果居然是:2013-613566753

问度娘完全没有参考的东西可看。头痛了半天,最后想到如下解决办法:

仍旧是以2013年第28周来比较:

SELECT date_format(CURDATE(),'%Y') = date_format(STR_TO_DATE('2013年第28周',"%Y年"),'%Y') and date_format(CURDATE(),'%u') = (select SUBSTR('2013年第28周' FROM 7 FOR 2)) ;     输出:1
로그인 후 복사

 

 

bitsCN.com
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿