MySQL中日期函数的使用

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> select QUARTER('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') 日期时间字符串

猜你喜欢

转载自www.cnblogs.com/leiblog/p/10029172.html