MySQLの日付操作(今月、先月の時間)

1.間隔の説明:

1.1。関数、つまり、interval()が使用される場合、それは次のような比較関数です:interval(10,1,3,5,7);結果は4;

原則:10は比較する数値で、次の1、3、5、7は比較数値です。次の4つを10と順に比較します。次の数値グループの数が10未満である数を確認し、それらの数値を返します。以下の番号グループは小さいものから大きいものへと配置されていることが前提です。それ以外の場合、結果は0です。

1.2。キーワードを使用する場合、これはdate_add()およびdate_sub()関数で一般的に使用される時間間隔の設定を意味します。

例:間隔1日。時間間隔を1日に設定すると解釈されます。

3.月の初日

select date_add(curdate(), interval - day(curdate()) + 1 day);

今天是当月的第几天:SELECT DAYOFMONTH( NOW());

4.月の最終日

select last_day(curdate());

5.先月の初日

select date_add(curdate()-day(curdate())+1,interval -1 month);

6.先月の最終日

select last_day(date_sub(now(),interval 1 month));

7.翌月の初日

select date_add(curdate()-day(curdate())+1,interval 1 month);

8.翌月の最終日

select last_day(date_sub(now(),interval -1 month));

9.月の日数

select day(last_day(curdate()));

10.先月と今日の現在の日付

select date_sub(curdate(), interval 1 month);

11.前月と今日の現在時刻(タイムスタンプ)

select unix_timestamp(date_sub(now(),interval 1 month));

12.現在の時刻と前月の間の日数を取得します

select datediff(curdate(), date_sub(curdate(), interval 1 month));

13、今日

SELECT DATE_FORMAT(NOW(),'%Y-%m-%d 00:00:00') AS '今天开始';
SELECT DATE_FORMAT(NOW(),'%Y-%m-%d 23:59:59') AS '今天结束';

14、昨日

SELECT DATE_FORMAT( DATE_SUB(CURDATE(), INTERVAL 1 DAY), '%Y-%m-%d 00:00:00') AS '昨天开始';
SELECT DATE_FORMAT( DATE_SUB(CURDATE(), INTERVAL 1 DAY), '%Y-%m-%d 23:59:59') AS '昨天结束';

15.先週

SELECT DATE_FORMAT( DATE_SUB( DATE_SUB(CURDATE(), INTERVAL WEEKDAY(CURDATE()) DAY), INTERVAL 1 WEEK), '%Y-%m-%d 00:00:00') AS '上周一';
SELECT DATE_FORMAT( SUBDATE(CURDATE(), WEEKDAY(CURDATE()) + 1), '%Y-%m-%d 23:59:59') AS '上周末';

16.今週

SELECT DATE_FORMAT( SUBDATE(CURDATE(),DATE_FORMAT(CURDATE(),'%w')-1), '%Y-%m-%d 00:00:00') AS '本周一';
SELECT DATE_FORMAT( SUBDATE(CURDATE(),DATE_FORMAT(CURDATE(),'%w')-7), '%Y-%m-%d 23:59:59') AS '本周末';

-- 上面的本周算法会有问题,因为mysql是按照周日为一周第一天,如果当前是周日的话,会把时间定为到下一周.
SELECT DATE_FORMAT( DATE_SUB(CURDATE(), INTERVAL WEEKDAY(CURDATE()) DAY), '%Y-%m-%d 00:00:00') AS '本周一';
SELECT DATE_FORMAT( DATE_ADD(SUBDATE(CURDATE(), WEEKDAY(CURDATE())), INTERVAL 6 DAY), '%Y-%m-%d 23:59:59') AS '本周末';

17、上月

SELECT DATE_FORMAT( DATE_SUB(CURDATE(), INTERVAL 1 MONTH), '%Y-%m-01 00:00:00') AS '上月初';
SELECT DATE_FORMAT( LAST_DAY(DATE_SUB(CURDATE(), INTERVAL 1 MONTH)), '%Y-%m-%d 23:59:59') AS '上月末';

18.今月

SELECT DATE_FORMAT( CURDATE(), '%Y-%m-01 00:00:00') AS '本月初';
SELECT DATE_FORMAT( LAST_DAY(CURDATE()), '%Y-%m-%d 23:59:59') AS '本月末';

19.年の最初の日

SELECT DATE_SUB(CURDATE(),INTERVAL dayofyear(now())-1 DAY)  

或

concat(year(now()),'-01-01')//当前年份的第一天
concat(year(now()),'-12-31')//当前年份的最后一天

20.時差変換

SELECT 
	TIME_TO_SEC(TIMEDIFF('2018-09-30 19:38:45', '2018-08-23 10:13:01')) AS DIFF_SECOND1, -- 秒
	UNIX_TIMESTAMP('2018-09-30 19:38:45')-UNIX_TIMESTAMP('2018-08-23 10:13:01') AS DIFF_SECOND2, -- 秒
	TIMESTAMPDIFF(SECOND,'2018-08-23 10:13:01','2018-09-30 19:38:45') AS DIFF_SECOND3, -- 秒
	TIMESTAMPDIFF(MINUTE,'2018-08-23 10:13:01','2018-09-30 19:38:45') AS DIFF_MINUTE, -- 分
	TIMESTAMPDIFF(HOUR,'2018-08-23 10:13:01','2018-09-30 19:38:45') AS DIFF_HOUR, -- 小时
	TIMESTAMPDIFF(DAY ,'2018-08-23 10:13:01','2018-09-30 19:38:45') AS DIFF_DATE1, -- 天
	DATEDIFF('2018-09-30 19:38:45','2018-08-23 10:13:01') AS DIFF_DATE2, -- 天
	TIMESTAMPDIFF(MONTH,'2018-08-23 10:13:01','2018-09-25 19:38:45') AS DIFF_MONTH, -- 月
	TIMESTAMPDIFF(YEAR,'2018-08-23 10:13:01','2020-07-25 19:38:45') AS DIFF_YEAR -- 年
FROM DUAL;

21.日付は年、月、日、時、分、秒を追加します

select date_add(日期, interval 1 day); 日期加天
select date_add(日期, interval 1 hour); 日期加小时
select date_add(日期, interval 1 minute); 日期加分
select date_add(日期, interval 1 second);日期加秒
select date_add(日期, interval 1 microsecond); 日期加微秒
select date_add(日期, interval 1 week); 日期加周
select date_add(日期, interval 1 month); 日期加月
select date_add(日期, interval 1 quarter); 日期加季度
select date_add(日期, interval 1 year); 日期加年

22.当月サイクルのすべての日(入力日は当月の日数に自動的に変換されます) 

SELECT ADDDATE(y.first, x.d - 1) as d 
FROM (
	SELECT 1 AS d UNION ALL
	SELECT 2 UNION ALL
	SELECT 3 UNION ALL
	SELECT 4 UNION ALL
	SELECT 5 UNION ALL
	SELECT 6 UNION ALL
	SELECT 7 UNION ALL
	SELECT 8 UNION ALL
	SELECT 9 UNION ALL
	SELECT 10 UNION ALL
	SELECT 11 UNION ALL
	SELECT 12 UNION ALL
	SELECT 13 UNION ALL
	SELECT 14 UNION ALL
	SELECT 15 UNION ALL
	SELECT 16 UNION ALL
	SELECT 17 UNION ALL
	SELECT 18 UNION ALL
	SELECT 19 UNION ALL
	SELECT 20 UNION ALL
	SELECT 21 UNION ALL
	SELECT 22 UNION ALL
	SELECT 23 UNION ALL
	SELECT 24 UNION ALL
	SELECT 25 UNION ALL
	SELECT 26 UNION ALL
	SELECT 27 UNION ALL
	SELECT 28 UNION ALL
	SELECT 29 UNION ALL
	SELECT 30 UNION ALL
	SELECT 31
) x,
(
	SELECT '2019-09-05' - INTERVAL DAY('2019-09-05') - 1 DAY AS first, DAY(LAST_DAY('2019-09-05')) AS last 
) y
WHERE x.d <= y.last

23. 12か月の日付をシミュレートする

SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-01-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-01-31'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-02-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-02-28'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-03-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-03-31'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-04-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-04-30'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-05-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-05-31'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-06-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-06-30'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-07-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-07-31'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-08-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-08-31'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-09-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-09-30'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-10-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-10-31'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-11-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-11-30'),'%Y-%m-%d') END_V
UNION
SELECT STR_TO_DATE(CONCAT(YEAR(now()),'-12-01'),'%Y-%m-%d') BEGIN_V,STR_TO_DATE(CONCAT(YEAR(now()),'-12-31'),'%Y-%m-%d') END_V

24、

    #当年第一天:  
    SELECT DATE_SUB(CURDATE(),INTERVAL dayofyear(now())-1 DAY);  
      
    #当年最后一天:  
    SELECT concat(YEAR(now()),'-12-31');    
      
    #当前week的第一天:    
    select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) + 1 DAY);  
      
    #当前week的最后一天:    
    select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) - 5 DAY);  
      
    #前一week的第一天:    
    select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) + 8 DAY);  
      
    #前一week的最后一天:    
    select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) + 2 DAY);  
      
    #前两week的第一天:    
    select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) + 15 DAY);  
      
    #前两week的最后一天:    
    select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) + 9 DAY);  
      
    #当前month的第一天:    
    SELECT concat(date_format(LAST_DAY(now()),'%Y-%m-'),'01');  
      
    #当前month的最后一天:    
    SELECT  LAST_DAY(now());  
      
    #前一month的第一天:    
    SELECT concat(date_format(LAST_DAY(now() - interval 1 month),'%Y-%m-'),'01');  
      
    #前一month的最后一天:    
    SELECT LAST_DAY(now() - interval 1 month);  
      
    #前两month的第一天:    
    SELECT concat(date_format(LAST_DAY(now() - interval 2 month),'%Y-%m-'),'01');  
      
    #前两month的最后一天:    
    SELECT  LAST_DAY(now() - interval 2 month);  
      
    #当前quarter的第一天:    
    select concat(date_format(LAST_DAY(MAKEDATE(EXTRACT(YEAR FROM  CURDATE()),1) + interval QUARTER(CURDATE())*3-3 month),'%Y-%m-'),'01');   
      
    #当前quarter的最后一天:    
    select LAST_DAY(MAKEDATE(EXTRACT(YEAR  FROM CURDATE()),1) + interval QUARTER(CURDATE())*3-1 month);  
      
    #前一quarter的第一天:    
    select concat(date_format(LAST_DAY(MAKEDATE(EXTRACT(YEAR FROM CURDATE()),1) + interval QUARTER(CURDATE())*3-6 month),'%Y-%m-'),'01');  
      
    #前一quarter的最后一天:    
    select  LAST_DAY(MAKEDATE(EXTRACT(YEAR FROM CURDATE()),1) + interval QUARTER(CURDATE())*3-4 month);  
      
    #前两quarter的第一天:    
    select concat(date_format(LAST_DAY(MAKEDATE(EXTRACT(YEAR FROM CURDATE()),1) + interval QUARTER(CURDATE())*3-9 month),'%Y-%m-'),'01');  
      
    #前两quarter的最后一天:    
    select LAST_DAY(MAKEDATE(EXTRACT(YEAR FROM CURDATE()),1) + interval QUARTER(CURDATE())*3-7 month); 

 

 

おすすめ

転載: blog.csdn.net/bj_chengrong/article/details/100655333