mysql 擷取當前日期前後的時間

來源:互聯網
上載者:User

標籤:mysql 擷取當前日期對應周一或周日

selectsubdate(curdate(),date_format(curdate(),‘%w‘)-1)//擷取當前日期在本周的周一


selectsubdate(curdate(),date_format(curdate(),‘%w‘)-7)//擷取當前日期在本周的周日


這兩句語句是mysql用來取當前日期的周一或周日的一個方法,那麼這句如何運作的呢?

%w是以數位形式來表示周中的天數(0=Sunday,1=Monday,...,6=Saturday),0為周日,6為周六,跟我們一般的認知,一周是從周一開始的並不一樣。

date_format是一個日期轉換函式

date_format(curdate(),‘%w‘) 表示當前日期到上周周日共有幾天的間隔,即當前日期減去上周周日的日期=天數(例:curdate()為2011-01-11,那麼上周周日為 2011-01-09,兩者相減為2)所以若單獨輸出這一句:selectdate_format(curdate(),‘%w‘)結果就是2

在mysqlapi裡對於subdate函數是這樣解釋的:


SELECTSUBDATE(NOW(),1)AS‘Yesterday‘,


SUBDATE(NOW(),INTERVAL-1DAY)AS‘Tomorrow‘;


正值為昨天,負值為明天,目前時間的起點,就是目前時間的上周周日

subdate函數就是用目前時間減去2天,得到上周周日的時間為2011-01-09


那麼如果運行selectsubdate(curdate(),date_format(curdate(),‘%w‘)-2)這句,就表示用目前時間-(2-2),即-0,得到的結果就是當前日期本身了。

如果把%w換成%d呢


%d是用兩位元字來表示月中的天數(00,01,...,31)


直接輸出的結果就應該是11,表示當前日期在一個月內是第幾天


selectdate_format(‘2011-01-11‘,‘%d‘)


放到開始的語句裡就表示用目前時間減去11,結果為2010-12-31


selectsubdate(‘2011-01-11‘,date_format(‘2011-01-11‘,‘%d‘))


mysql 資料庫中根據當前系統時間,取前後幾秒 幾分鐘 幾小時 幾天

取當前時間:

select current_timestamp;

輸出:2016-06-16 16:12:52

select now(); 

輸出:2016-06-16 16:12:52


取當前時間的前一分鐘:

select SUBDATE(now(),interval 60 second);

輸出:2016-06-16 16:11:52


取目前時間的下一分鐘:
select ADDDATE(now(),interval 60 second);

輸出:2016-06-16 16:13:52


通過變化上面的單位。可以取前後  分鐘,小時,天的時間

取前一分鐘的時間:

select SUBDATE(now(),interval 1 minute);

輸出:2016-06-16 16:16:38

取前一小時的時間:

select SUBDATE(now(),interval 1 hour);

輸出:2016-06-16 15:17:38

取前一天的時間:

select SUBDATE(now(),interval 1 day);

輸出:2016-06-15 16:17:38

###########################

取後一分鐘的時間:

select ADDDATE(now(),interval 1 minute);

輸出:2016-06-16 16:17:38

取後一小時的時間:

select ADDDATE(now(),interval 1 hour);

輸出:2016-06-16 17:17:38

取後一天的時間:

select ADDDATE(now(),interval 1 day);

輸出:2016-06-17 16:17:38

本文出自http://www.th7.cn/db/mysql/201606/192064.shtml

本文出自 “夢想照進現實” 部落格,請務必保留此出處http://lookingdream.blog.51cto.com/5177800/1916695

mysql 擷取當前日期前後的時間

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.