MySQL中日期函式的使用
阿新 • • 發佈:2018-11-27
1. MySQL中的日期函式
1.1. 轉DATETIME型別為Date型別
將add_time=2013-01-12 23:23:56轉化為date型別 select * from product where Date(add_time) = '2013-01-12'
1.2. 獲取時間中的年、月、日
select * from product where Year(add_time) = 2013 and Month(add_time) = 1
1.3. 獲取日期是本年的第幾天, 值在1到366之間
mysql> select DAYOFYEAR('1998-02-03'); -> 34
1.4. 獲取日期是本月的第幾天, 值在1到31之間
mysql> select DAYOFMONTH('1998-02-03'); -> 3
1.5. 獲取日期是本週的第幾天, 值在1到7之間
返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六),這些索引值對應於ODBC標準。
mysql> select DAYOFWEEK('1998-02-03'); -> 3
1.6. 獲取日期的星期索引
返回日期的星期索引(0=星期一,1=星期二, ……6= 星期天)
mysql>select WEEKDAY('1997-10-04 22:23:00'); -> 5 mysql> select WEEKDAY('1997-11-05'); -> 2
1.7. 獲取日期的月份英文名
mysql> select MONTHNAME("1998-02-05"); -> 'February'
1.8. 獲取日期是星期幾
mysql> select DAYNAME("1998-02-05"); -> 'Thursday'
1.9. 獲取日期是本年的哪一季度,取值1到4
mysql> selectQUARTER('98-04-01'); -> 2
1.10. 求兩日期間的間隔天數
mysql> SELECT something FROM table WHERE TO_DAYS(endTime) - TO_DAYS(beginTime) <= 30;
1.11. 日期加減函式
date_add('2012-05-25', interval 1 day) 表示 2012-05-26 date_add('2012-05-25', interval -1 day) 表示 2012-05-24 date_sub('2012-05-25',interval 1 day) 表示 2012-05-24 date_sub('2012-05-25',interval -1 day) 表示 2012-05-26 //括號裡的引數day可以換成month及year
1.12. 獲取當前的日期、時間以及日期時間
獲得當前日期(date)函式:curdate() 獲得當前時間(time)函式:curtime() 獲得當前日期+時間(date + time)函式:sysdate() sysdate() 日期時間函式跟 now() 類似,不同之處在於:now() 在執行開始時值就得到了, sysdate() 在函式執行時動態得到值。
1.3. 將日期時間轉換成對應的字串
SELECT DATE_FORMAT(NOW(),'%Y%m%d') 日期字串,DATE_FORMAT(NOW(), '%Y%m%d%H%i%s') 日期時間字串