成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

mysql中如何計算日期和時間的間隔

這篇文章主要介紹MySQL中如何計算日期和時間的間隔,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比密山網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式密山網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋密山地區(qū)。費用合理售后完善,十年實體公司更值得信賴。

具體如下:

我們首先得明確一點,mysql間隔值主要用于日期和時間計算,如果我們要要創(chuàng)建間隔值,可以使用以下表達式:

INTERVAL expr unit

然后嘞,我們得了解,INTERVAL關(guān)鍵字是確定間隔值的expr,以及指定間隔單位的單位。 例如,要創(chuàng)建1天間隔,我們就要使用以下表達式:

INTERVAL 1 DAY

不過我們要注意,INTERVAL和UNIT不區(qū)分大小寫,因此以下表達式與上述表達式相當:

interval 1 day

日期和時間算術(shù)的間隔值的實際用法和語法,我們可以看下面的代碼:

date + INTERVAL expr unit
date - INTERVAL expr unit

間隔值同樣也用于各種時間函數(shù),如DATE_ADD,DATE_SUB,TIMESTAMPADD和TIMESTAMPDIFF。mysql定義了expr和unit的標準格式,如下表所示:

單位(unit)表達式(expr)
DAYDAYS
DAY_HOUR‘DAYS HOURS'
DAY_MICROSECOND‘DAYS HOURS:MINUTES:SECONDS.MICROSECONDS'
DAY_MINUTE‘DAYS HOURS:MINUTES'
DAY_SECOND‘DAYS HOURS:MINUTES:SECONDS'
HOURHOURS
HOUR_MICROSECOND‘HOURS:MINUTES:SECONDS.MICROSECONDS'
HOUR_MINUTE‘HOURS:MINUTES'
HOUR_SECOND‘HOURS:MINUTES:SECONDS'
MICROSECONDMICROSECONDS
MINUTEMINUTES
MINUTE_MICROSECOND‘MINUTES:SECONDS.MICROSECONDS'
MINUTE_SECOND‘MINUTES:SECONDS'
MONTHMONTHS
QUARTERQUARTERS
SECONDSECONDS
SECOND_MICROSECOND‘SECONDS.MICROSECONDS'
WEEKWEEKS
YEARYEARS
YEAR_MONTH‘YEARS-MONTHS'

我們來看個實例,下面的sql語句在2020-01-01日期上增加1天返回結(jié)果為,2020-01-02:

mysql> SELECT '2020-01-01' + INTERVAL 1 DAY;
+-------------------------------+
| '2020-01-01' + INTERVAL 1 DAY |
+-------------------------------+
| 2020-01-02          |
+-------------------------------+
1 row in set (0.01 sec)

如果我們在涉及DATE或DATETIME值的表達式中使用了間隔值,并且間隔值位于表達式的右側(cè),則可以使用expr的負值,如以下示例所示:

mysql> SELECT '2020-01-01' + INTERVAL -1 DAY;
+--------------------------------+
| '2020-01-01' + INTERVAL -1 DAY |
+--------------------------------+
| 2019-12-31           |
+--------------------------------+
1 row in set

我們再來看如何使用DATE_ADD和DATE_SUB從日期值添加/減去1個月:

mysql> SELECT DATE_ADD('2020-01-01', INTERVAL 1 MONTH) 1_MONTH_LATER, 
    DATE_SUB('2020-01-01',INTERVAL 1 MONTH) 1_MONTH_BEFORE;
+---------------+----------------+
| 1_MONTH_LATER | 1_MONTH_BEFORE |
+---------------+----------------+
| 2020-02-01  | 2019-12-01   |
+---------------+----------------+
1 row in set

完事再來看一個sql使用TIMESTAMPADD(unit,interval,expression)函數(shù)向時間戳值添加30分鐘:

mysql> SELECT TIMESTAMPADD(MINUTE,30,'2020-01-01') 30_MINUTES_LATER;
+---------------------+
| 30_MINUTES_LATER  |
+---------------------+
| 2020-01-01 00:30:00 |
+---------------------+
1 row in set

說這么多,大家可能還有點懵,不怕,來看具體的操作,我們創(chuàng)建一個名為memberships的新表,用于演示:

CREATE TABLE memberships (
  id INT AUTO_INCREMENT PRIMARY KEY,
  email VARCHAR(355) NOT NULL,
  plan VARCHAR(255) NOT NULL,
  expired_date DATE NOT NULL
);

在上面的memberships表中,expired_date列存儲每個會員的會員資格到期日,完事我們插入一部分數(shù)據(jù)到memberships表中:

INSERT INTO memberships(email, plan, expired_date)
VALUES('john.doe@yiibai.com','Gold','2018-07-13'),
   ('jane.minsu@yiibai.com','Platinum','2018-07-10'),
   ('david.corp@yiibai.com','Silver','2018-07-15'),
   ('julia.william@yiibai.com','Gold','2018-07-20'),
   ('peter.drucker@yiibai.com','Silver','2018-07-08');

現(xiàn)在我們來假設(shè)今天是2018-07-06,然后我們來使用sql語句查詢在未來7天內(nèi)會員資格將要過期的會員:

SELECT 
  email,
  plan,
  expired_date,
  DATEDIFF(expired_date, '2018-07-06') remaining_days
FROM
  memberships
WHERE
  '2018-07-06' BETWEEN DATE_SUB(expired_date, INTERVAL 7 DAY) AND expired_date;

執(zhí)行上面查詢語句后,得到以下結(jié)果:

+--------------------------+----------+--------------+----------------+
| email          | plan   | expired_date | remaining_days |
+--------------------------+----------+--------------+----------------+
| john.doe@yiibai.com   | Gold   | 2018-07-13  |       7 |
| jane.minsu@yiibai.com  | Platinum | 2018-07-10  |       4 |
| peter.drucker@yiibai.com | Silver  | 2018-07-08  |       2 |
+--------------------------+----------+--------------+----------------+
3 rows in set

在上面的sql中,DATE_SUB函數(shù)將間隔值(INTERVAL 7 DAY)指定的過期日期減去7天,也就是說,本來某條數(shù)據(jù)的日期是13號,減去七天,那就是6號了。大概就是這個意思了,相信大家都有一定的理解了。

以上是“mysql中如何計算日期和時間的間隔”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

當前題目:mysql中如何計算日期和時間的間隔
文章分享:http://jinyejixie.com/article48/ggeshp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、App設(shè)計網(wǎng)站導航、自適應網(wǎng)站、、Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)
环江| 阜平县| 岗巴县| 沙河市| 阿克陶县| 香格里拉县| 磴口县| 全州县| 洛浦县| 财经| 古交市| 容城县| 梨树县| 宜宾市| 贞丰县| 田林县| 塔河县| 容城县| 揭东县| 永丰县| 阳高县| 神木县| 商河县| 伊金霍洛旗| 西林县| 永和县| 安康市| 河津市| 从化市| 瑞昌市| 会泽县| 都昌县| 柏乡县| 木里| 兴城市| 洛阳市| 宣汉县| 五家渠市| 武乡县| 郸城县| 湖南省|