1,CURDATE()或CURRENT_DATE()和CURTIME()或CURRENT_TIME()

这两个函数是比较常用到的,顾名思义,第一个返回当前日期,第二个返回当前时间

可以在MySQL客户端或者PHP语句里写"SELECT CURDATE(),CURTIME()"查看相关信息.

还有一个很重要的函数NOW(),返回当前日期和时间其实就是上面两个函数返回结果的合并。

2,DATE_ADD和DATE_SUB(date,INTERVAL int keyword)

这两个函数很重要,返回日期date加上或减去格式化的时间INTERVAL int,像今天有个朋友提到如何查询一周之内的数据就要用到这个函数。

下面讲一下INTERVAL int keyword

例1:

复制代码 代码示例:

SELECT  *  FROM tblname WHERE TIME > DATE_SUB ( NOW (), INTERVAL 1 MONTH )

这个语句执行后返回表中所有TIME字段值从当前日期起一个月之内的数据

例2,

复制代码 代码示例:

SELECT  *  FROM tblname WHERE TIME > DATE_SUB ( NOW (), INTERVAL  "1-1"  YEAR_MONTH )

这个语句返回距今一年零一个月之内的数据

如果用到DAY_SECOND参数,前面的int就必须如 "1 12:23:34"这样的格式

keyword参数列表

MICROSECOND

SECOND

MINUTE

HOUR

DAY

WEEK

MONTH

QUARTER

YEAR

SECOND_MICROSECOND

MINUTE_MICROSECOND

MINUTE_SECOND

HOUR_MICROSECOND

HOUR_SECOND

HOUR_MINUTE

DAY_MICROSECOND

DAY_SECOND

DAY_MINUTE

DAY_HOUR

YEAR_MONTH

其中QUARTER和WEEK是MySQL5之后才有的。

EXTRACT(keyword FROM date)-这个函数从提供的日期中摘取出相关信息

例3,

复制代码 代码示例:

SELECT EXTRACT ( DAY FROM NOW ())

就返回当前日期的DAY,今天是16日就返回数字16。

几个日期时间函数

DAYOFWEEK(NOW())返回当前日期是这周的第一天,周日是第一天,

DAYNAME(NOW())返回星期的名字

DAYOFMONTH(NOW()) 返回今天是几号

DAYOFYEAR(NOW()) 返回今天是今年的第多少天

YEAR(NOW()) WEEK(NOW()) MONTH(NOW()) HOUR(NOW()) MINUTE(NOW()) QUARTER(NOW()) SECOND(NOW())

上面都不用说了,分别返回年,周,月,小时,分钟,秒

为什么没有日期呢?因为DAYOFMONTH(NOW())就是啊!

那么对于时间戳怎么处理呢?有两个函数

UNIX_TIMESTAMP(NOW())返回当前时间的UNIX时间戳

FROM_UNIXTIME(int) 根据UNIX时间戳返回默认格式的时间日期

TIME_TO_SEC和SEC_TO_TIME分别在数字秒数和时间秒数之间转化

比如TIME_TO_SEC("1:00:00");返回一小时的秒数

还有两个不太用到的函数

TO_DAYS(date) 返回从0年到date的总天数

FROM_DAYS(x) 进行相反的操作

还有2个函数

PERIOD_ADD(date,month)这个函数需要的DATE格式是这样的200610,

PERIOD_ADD(200610,-2)返回200608

而另一个函数

PERIOD_DIFF(200608,200610)返回也是-2

下面是时间日期函数最后的一个重点:格式化

学过C语言的人都知道printf里面的参数%s,%d等等吧。

% a  -   缩写的星期名

% b  -   缩写的月份名

% d  -  月份中的天数

% H  -  小时 [ 带前导零 ]

% I  -   分钟 [ 带前导零 ]

% j  -  一年中的天数

% m  -  月份 [ 带前导零 ]

% M  -  月份 [ 完整 ]

% p  - [ AM或PM ]

% r  -  时间 [ 12小时格式 ]

% S  -  秒 [ 带前导零 ]

% T  -  时间 [ 24小时格式 ]

% w  -  一周中的天数 [ 0 - 6 ]- 这里想不通为什么DAYOFWEEK返回的是1 - 7

% W  -  星期名 [ 完整 ]

% Y  -  年份 [ 4位数 ]

例子,

复制代码 代码示例:

SELECT DATE_FORMAT ( NOW (), "%Y-%m-%d" )

上面这句话返回2006 - 10 - 16

还有FROM_UNIXTIME()函数的用法:

复制代码 代码示例:

mysql> SELECT FROM_UNIXTIME(875996580);

-> '1997-10-04 22:23:00'

mysql> SELECT FROM_UNIXTIME(875996580) + 0;

-> 19971004222300

mysql> SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(), '%Y %D %M %h:%i:%s %x');

-> '2003 6th August 06:22:58 2003'

例子,

复制代码 代码示例:

select *,from_unixtime(`datetime`,"%Y-%m-%d") from table

table换成你的表,datetime是你的int型字段名,ok 了试一下吧。

有关MySQL函数的介绍就介绍这些了,更多内容参考mysql手册。