sql語句中日期相減的操作實(shí)例代碼
1. 直接用日期時間做減法
GETDATE() 和 NOW() 查出來的時間一樣,都帶時分秒
select GETDATE(),NOW() FROM t_表名;
curdate() 只顯示 年月日
select curdate(),NOW() FROM TB_表名;
如果直接做減法,只能得到兩個時間相差多少天
select (NOW()-日期時間字段) FROM T_表名;
若不要 時分秒,可以考慮用 curdate()
select (curdate()-日期時間字段) FROM T_表名;
2. 使用 datediff 函數(shù)
datediff 函數(shù)還有其他的玩法,在這就不多加贅述了。 兩日期 間隔年
select datediff(year, 開始日期,結(jié)束日期) FROM T_表名;;
倆日期 間隔季
select datediff(quarter, 開始日期,結(jié)束日期) FROM T_表名;
倆日期 間隔月
select datediff(month, 開始日期,結(jié)束日期) from 表名;
倆日期 間隔天
select datediff(day, 開始日期,結(jié)束日期) FROM T_表名;
倆日期 間隔周
select datediff(week, 開始日期,結(jié)束日期) FROM T_表名;
倆日期 間隔小時
select datediff(hour, 開始日期,結(jié)束日期) FROM T_表名;
倆日期 間隔分
select datediff(minute, 開始日期,結(jié)束日期) FROM T_表名;
倆日期 間隔秒
select datediff(second, 開始日期,結(jié)束日期) FROM T_表名;
獲取近 7 天 的年月日,包括今天
select (CURDATE() - 6) as dateList union select (CURDATE() - 5) as dateList union select (CURDATE() - 4) as dateList union select (CURDATE() - 3) as dateList union select (CURDATE() - 2) as dateList union select (CURDATE() - 1) as dateList union select (CURDATE() - 0) as dateList
查詢 當(dāng)前 年月日 時分秒
SELECT NOW(), CURDATE(), CURTIME()
好的代碼像粥一樣,都是用時間熬出來的
補(bǔ)充:下面來看個實(shí)例
我有一個表,其中有四個字段:開始天數(shù),開始時間,到達(dá)天數(shù),到達(dá)時間(這四個字段都是varchar類型)
例如:某一條記錄: 1 16:00 2 12:20
我的目的就是用 select(到達(dá)天數(shù)+到達(dá)時間)-(開始天數(shù)+開始時間) as 花費(fèi)時間 from table
例如上條記錄得到的就是 (2*24:00+12:20)-(24:00+16:00)=20:00
這樣的sql語句該怎么寫???
declare @t table ( beginday int, begintime varchar(20), endday int, endtime varchar(20) ) insert @t select 1,"16:00",2,"12:20" union all select 1,"3:00",3,"19:10" select date=rtrim(date/60)+":"+rtrim(date%60) from (select date=datediff(mi,1,dateadd(d,endday-beginday,beginday)-begintime+endtime)from @t )t date ------------------------- 20:20 64:10
方法二
declare @t table(開始天數(shù) varchar(10),開始時間 varchar(10),到達(dá)天數(shù) varchar(10),到達(dá)時間 varchar(10)) insert @t select "1", "16:00","2","12:20" --如果開始天數(shù),到達(dá)天數(shù)大于31 select 到達(dá)天數(shù) * 24 + datepart(hh,到達(dá)時間) - 開始天數(shù) * 24 - datepart(hh,開始時間) from @t
總結(jié)
到此這篇關(guān)于sql語句中日期相減操作的文章就介紹到這了,更多相關(guān)sql語句日期相減內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
select count()和select count(1)的區(qū)別和執(zhí)行方式講解
今天小編就為大家分享一篇關(guān)于select count()和select count(1)的區(qū)別和執(zhí)行方式講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03
mysql實(shí)現(xiàn)查詢最接近的記錄數(shù)據(jù)示例
這篇文章主要介紹了mysql實(shí)現(xiàn)查詢最接近的記錄數(shù)據(jù),涉及mysql查詢相關(guān)的時間轉(zhuǎn)換、排序等相關(guān)操作技巧,需要的朋友可以參考下2018-07-07
MySQL 撤銷日志與重做日志(Undo Log與Redo Log)相關(guān)總結(jié)
這篇文章主要介紹了MySQL 撤銷日志與重做日志(Undo Log與Redo Log)相關(guān)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下2021-03-03
詳解如何通過Mysql的二進(jìn)制日志恢復(fù)數(shù)據(jù)庫數(shù)據(jù)
本篇文章主要介紹了詳解如何通過Mysql的二進(jìn)制日志恢復(fù)數(shù)據(jù)庫數(shù)據(jù),具有一定的參考價值,有興趣的可以了解一下。2017-04-04
asp+mysql+utf8 網(wǎng)頁出現(xiàn)亂碼問題的解決方法
無論在網(wǎng)頁中加多少UTF8的定義,顯示的結(jié)果都還是會有一些小格子,反而定義為gb2312,顯示完全正常2014-03-03
mysql8.0數(shù)據(jù)庫無法被遠(yuǎn)程連接問題排查小結(jié)
本文主要介紹了mysql8.0數(shù)據(jù)庫無法被遠(yuǎn)程連接問題排查小結(jié)2024-07-07

