可以通過SELECT DATEADD(day, 相差天數(shù), 日期) AS 別名 的格式來計算上周SELECT DATEADD(day, -7, 日期) AS 別名上月SELECT DATEADD(month, -1, 日期) AS 別名上年SELECT DATEADD(year, -1, 日期) AS 別名
企業(yè)建站必須是能夠以充分展現(xiàn)企業(yè)形象為主要目的,是企業(yè)文化與產(chǎn)品對外擴展宣傳的重要窗口,一個合格的網(wǎng)站不僅僅能為公司帶來巨大的互聯(lián)網(wǎng)上的收集和信息發(fā)布平臺,創(chuàng)新互聯(lián)公司面向各種領(lǐng)域:圍欄護欄等網(wǎng)站設(shè)計、成都營銷網(wǎng)站建設(shè)解決方案、網(wǎng)站設(shè)計等建站排名服務(wù)。
1. MySQL 為日期增加一個時間間隔:date_add()
set @dt = now();
select date_add(@dt, interval 1 day); - 加1天
select date_add(@dt, interval 1 hour); -加1小時
select date_add(@dt, interval 1 minute); - 加1分鐘
select date_add(@dt, interval 1 second); -加1秒
select date_add(@dt, interval 1 microsecond);-加1毫秒
select date_add(@dt, interval 1 week);-加1周
select date_add(@dt, interval 1 month);-加1月
select date_add(@dt, interval 1 quarter);-加1季
select date_add(@dt, interval 1 year);-加1年
MySQL adddate(), addtime()函數(shù),可以用date_add() 來替代。
下面是date_add() 實現(xiàn)addtime() 功能示例:
mysql set @dt = '2009-09-09 12:12:33';
mysql
mysql select date_add(@dt, interval '01:15:30' hour_second);-加上1小時15分30秒
date_add(@dt, interval '01:15:30' hour_second)
結(jié)果:2009-09-09 13:28:03
mysql select date_add(@dt, interval '1 01:15:30' day_second);-加1天1小時15分30秒
date_add(@dt, interval '1 01:15:30' day_second)
2008-08-10 13:28:03
date_add()函數(shù),分別為@dt 增加了“1小時15分30秒”和“1天1小時15分30秒”
2. MySQL 為日期減去一個時間間隔:date_sub()
mysql select date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second);
date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second)
MySQL date_sub() 日期時間函數(shù) 和date_add() 用法一致。
另外,MySQL 中還有兩個函數(shù)subdate(),subtime(),建議,用date_sub()來替代。
3. MySQL 另類日期函數(shù):period_add(P,N), period_diff(P1,P2)
函數(shù)參數(shù)“P”的格式為YYYYMM或者YYMM,第二個參數(shù)N表示增加或減去N month(月)。
MySQL period_add(P,N):日期加/減去N月。
mysql select period_add(200808,2), period_add(20080808,-2)
| period_add(200808,2) | period_add(20080808,-2) |
結(jié)果|200810 | 20080806 |
MySQL period_diff(P1,P2):日期P1-P2,返回N 個月。
mysql select period_diff(200808, 200801);
period_diff(200808, 200801)
結(jié)果:7
MySQL中,這兩個日期函數(shù),一般情況下很少用到。
4. MySQL日期、時間相減函數(shù):datediff(date1,date2), timediff(time1,time2)
MySQL datediff(date1,date2):兩個日期相減date1 date2,返回天數(shù)。
select datediff('2008-08-08', '2008-08-01'); - 7
select datediff('2008-08-01', '2008-08-08'); -7
MySQL timediff(time1,time2):兩個日期相減time1 time2,返回time差值。
select timediff('2008-08-08 08:08:08', '2008-08-08 00:00:00');- 08:08:08
select timediff('08:08:08', '00:00:00'); - 08:08:08
注意:timediff(time1,time2) 函數(shù)的兩個參數(shù)類型必須相同。
兩個日期變量或字段可直接相減,得到天數(shù)。
也可以日期減一個整數(shù),得到日期。
你可以試試的,實踐出真知
SQL語句使用DATEADD得到一個時間加上或減去指定天數(shù)之后的時間。也適用于小時、分鐘、秒鐘等等
DATEADD() 函數(shù)功能:在日期中添加或減去指定的時間間
語法:DATEADD(datepart,number,date)
date?參數(shù)是合法的日期表達式。number?是您希望添加的間隔數(shù);對于未來的時間,此數(shù)是正數(shù),對于過去的時間,此數(shù)是負(fù)數(shù)。
datepart?參數(shù)可以是下列的值:
下面已系統(tǒng)當(dāng)前時間(getdate())為例: