MySQL DATE_SUB()函數(shù)的實(shí)現(xiàn)示例
函數(shù)簡介
DATE_SUB()
函數(shù)從日期(DATE
或DATETIME
)中減去時(shí)間值(或間隔)。
語法
例如:數(shù)據(jù)傳輸過程中數(shù)據(jù)不時(shí)出現(xiàn)丟失的情況,偶爾會(huì)丟失一部分?jǐn)?shù)據(jù)
APP 中接收數(shù)據(jù)代碼:
DATE_SUB(date,INTERVAL expr type)
參數(shù)說明:
date 日期(時(shí)間)
expr 日期(時(shí)間)間隔
type 日期(時(shí)間)間隔單位
type 參數(shù)可以是下列值:
注意:type分為復(fù)合型和不復(fù)合型,不復(fù)合型的type可以和DATE_ADD()
函數(shù)通用,expr可以為負(fù)數(shù);復(fù)合型的type,參數(shù)用引號(hào)包起來,中間用字符間隔起來,不能使用負(fù)數(shù)。如果日期(時(shí)間)間隔只指定了一個(gè)值,也能正常執(zhí)行,但對(duì)應(yīng)XXX_YYY的type使用的是下劃線后YYY的單位,此時(shí)可以使用負(fù)數(shù)。
舉例
復(fù)合型
select date_add('2024-12-30', interval '1 2' YEAR_MONTH); #結(jié)果:2026-02-28 select date_add('2024-12-30', interval '1-2' YEAR_MONTH); #結(jié)果:2026-02-28 select date_add('2024-12-30', interval '1,2' YEAR_MONTH); #結(jié)果:2026-02-28 select date_add('2024-12-30', interval 1 YEAR_MONTH); #結(jié)果:2025-01-30 select date_add('2024-12-30', interval -1 YEAR_MONTH); #結(jié)果:2024-11-30 # 這里先減1年,再減2月,最后減1天,有點(diǎn)意思 select date_sub('2024-12-30', interval '1 2' YEAR_MONTH); #結(jié)果:2023-10-30 select date_sub('2024-12-30', interval '1-2' YEAR_MONTH); #結(jié)果:2023-10-30 select date_sub('2024-12-30', interval '1,2' YEAR_MONTH); #結(jié)果:2023-10-30 select date_sub('2024-12-30', interval 1 YEAR_MONTH); #結(jié)果:2024-11-30 select date_sub('2024-12-30', interval -1 YEAR_MONTH); #結(jié)果:2025-01-30
非復(fù)合型
select date_add(now(), interval 1 day); # 加1天 2024-12-31 15:44:20 select date_add(now(),INTERVAL -1 DAY); # 當(dāng)前日期向前推1天 2024-12-29 15:44:20 select date_add(now(), interval 1 hour);# 加1小時(shí) 2024-12-30 16:44:20 select date_add(now(), interval 1 minute); # 加1分鐘 2024-12-30 15:45:20 select date_add(now(), interval 1 second); # 加1秒 2024-12-30 15:44:21 select date_add(now(), interval 1 microsecond); # 加1毫秒 2024-12-30 15:44:20.000001 select date_add(now(), interval 1 week); # 加1周 2025-01-06 15:44:20 select date_add(now(), interval 1 month);# 加1月 2025-01-30 15:44:20 select date_add(now(), interval 1 quarter); # 加1季 2025-03-30 15:44:20 select date_add(now(), interval 1 year);# 加1年 2025-12-30 15:44:20 select date_sub(now(), interval 1 day); # 減1天 2024-12-29 15:45:42 select date_sub(now(),INTERVAL -1 DAY); # 當(dāng)前日期向后推1天 2024-12-31 15:45:42 select date_sub(now(), interval 1 hour);# 減1小時(shí) 2024-12-30 14:45:42 select date_sub(now(), interval 1 minute); # 減1分鐘 2024-12-30 15:44:42 select date_sub(now(), interval 1 second); # 減1秒 2024-12-30 15:45:41 select date_sub(now(), interval 1 microsecond); # 減1毫秒 2024-12-30 15:45:41.999999 select date_sub(now(), interval 1 week); # 減1周 2024-12-23 15:45:42 select date_sub(now(), interval 1 month);# 減1月 2024-11-30 15:45:42 select date_sub(now(), interval 1 quarter); # 加1季 2024-09-30 15:45:42 select date_sub(now(), interval 1 year);# 減1年 2023-12-30 15:45:42
無效或格式錯(cuò)誤的日期
SELECT DATE_SUB('2024-12-30', INTERVAL - 1 DAY); # NULL SELECT DATE_SUB('20-2412-30', INTERVAL - 1 DAY); # NULL
應(yīng)用場景
電商系統(tǒng),一個(gè)訂單客戶收貨后,7天自動(dòng)截單,一般會(huì)查詢超過七天未完成的訂單
SELECT * FROM sys_order WHERE state = 7 # 已收貨狀態(tài)是7 AND delivery_time <= DATE_SUB( NOW( ), INTERVAL 7 DAY ) # 這里將當(dāng)前時(shí)間減去7天后,再去和收貨時(shí)間進(jìn)行比較,小于或等于這個(gè)結(jié)果的都是收貨超過7天的訂單。
采購系統(tǒng)中,會(huì)創(chuàng)建采購評(píng)估單(類似電商系統(tǒng)購物車),后續(xù)可能將評(píng)估單轉(zhuǎn)為正式訂單,每個(gè)月都有評(píng)估單截止日期,并且會(huì)對(duì)截單日期進(jìn)行管理,我們會(huì)根據(jù)評(píng)估單的創(chuàng)建日期來判斷截單日期是哪一天,此時(shí)我們?nèi)绻肴≡u(píng)估單的截止日期(取得方式:如果評(píng)估單的創(chuàng)建時(shí)間在當(dāng)月截止日期之前或者截止日期當(dāng)天,則當(dāng)前評(píng)估單的的截止日期就是系統(tǒng)設(shè)定的下個(gè)月的截止日期,如果評(píng)估單的創(chuàng)建時(shí)間在本月截止日期之后,則當(dāng)前評(píng)估單的的截止日期就是系統(tǒng)設(shè)定的下下個(gè)月的截止日期)
例如
系統(tǒng)設(shè)定每月的截止日期:
2024年10月15日,2024年11月15日,2024年12月15日
①評(píng)估單的創(chuàng)建日期:2024年10月10日,評(píng)估單的截止日期:2024年11月15日
②評(píng)估單的創(chuàng)建日期:2024年10月15日,評(píng)估單的截止日期:2024年11月15日
③評(píng)估單的創(chuàng)建日期:2024年10月16日,評(píng)估單的截止日期:2024年12月15日
SELECT date FROM sys_deadline_setting WHERE date >= DATE_SUB( order_create_time, INTERVAL - 1 MONTH ) LIMIT 1
也可以這樣寫
SELECT date FROM sys_date_setting WHERE date >= DATE_ADD( order_create_time, INTERVAL 1 MONTH ) LIMIT 1
到此這篇關(guān)于MySQL DATE_SUB()函數(shù)的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)MySQL DATE_SUB() 函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL中存儲(chǔ)時(shí)間的最佳實(shí)踐指南
這篇文章主要給大家介紹了關(guān)于MySQL中存儲(chǔ)時(shí)間的最佳實(shí)踐,文中詳細(xì)介紹了哪種存儲(chǔ)時(shí)間的方式更好,對(duì)大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-07-07MySQL 實(shí)現(xiàn)樹的遍歷詳解及簡單實(shí)現(xiàn)示例
這篇文章主要介紹了MySQL 實(shí)現(xiàn)樹的遍歷詳解及簡單實(shí)現(xiàn)示例的相關(guān)資料,這里提供了示例代碼及測試結(jié)果,需要的朋友可以參考下2017-01-01sql中替換函數(shù)replace()用法與實(shí)例總結(jié)
這篇文章主要給大家介紹了關(guān)于sql中替換函數(shù)replace()用法與實(shí)例的相關(guān)資料,在SQL中REPLACE函數(shù)用于替換一個(gè)字符串中的一部分為另一個(gè)字符串,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02mySQL中in查詢與exists查詢的區(qū)別小結(jié)
最近被一個(gè)朋友問到mySQL中in查詢和exists的區(qū)別,當(dāng)然只是草草的回答了下,今天偶然看到了一篇關(guān)于mysql中的exists查詢的文章,讀完感覺太”冷落”它了,這里總結(jié)一下,也跟自己常用的in查詢做一下對(duì)比。有需要的朋友們可以參考借鑒,下面來一起學(xué)習(xí)學(xué)習(xí)吧。2016-11-11Mysql 9.0.0創(chuàng)新MSI安裝的實(shí)現(xiàn)
本文提供了MySQL 9.0.0版本的MSI安裝方法,包括安裝前的下載鏈接,安裝過程中的選項(xiàng)介紹,以及安裝完成后的配置指南,具有一定的參考價(jià)值,感興趣的可以了解一下2024-10-10MySQL數(shù)據(jù)庫輸入密碼后閃退問題的解決方法
這篇文章主要為大家詳細(xì)介紹了MySQL數(shù)據(jù)庫輸入密碼后閃退的問題及解決方案,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10MySQL不適合創(chuàng)建索引的11種情況示例分析
這篇文章介紹了在MySQL中不適合創(chuàng)建索引的11種情況,本文通過示例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2025-02-02