mysql中时间查询函数(包括时间戳)
来源:互联网 发布:下载的网站源码怎么用 编辑:程序博客网 时间:2024/06/05 18:03
这些函数都是MySQL自带的,可以直接使用在PHP写的MySQL查询语句中哦
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
先举个例子
SELECT * FROM tblname WHERE TIME>DATE_SUB(NOW(),INTERVAL 1 MONTH)
这个语句执行后返回表中所有TIME字段值从当前日期起一个月之内的数据
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)-这个函数从提供的日期中摘取出相关信息
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手册
- mysql中时间查询函数(包括时间戳)
- MySQL查询时间时间戳
- MySQL查询时间戳
- Mysql中查询系统时间
- Mysql中查询系统时间
- MySQL内置函数表(包括字符串函数、数学函数和日期时间函数)
- MySQL内建函数表(包括字符串函数、数学函数和日期时间函数)
- mysql时间戳函数
- MySQL 中,默认值时间函数
- orcl中查询两个时间的差值(包括时分秒)
- mysql查询条件时间戳按照时间查询
- mysql中通过时间/日期/时间日期类型条件查询
- Mysql中查询系统时间的方法
- mysql中时间字段的查询、应用
- mysql 查询中sending data 时间过长
- mysql中时间数据比较查询问题
- MySQL 时间戳(Timestamp)函数
- MySQL 时间戳(Timestamp)函数
- 极限编程读书笔记
- Silverlight游戏设计(Game Design):(六)场景编辑器之开源畅想
- 给研究生和博士后的资源
- linux和windows下面虚拟机的网络设置
- S60 3rd Fp2 UID (只作参考)!
- mysql中时间查询函数(包括时间戳)
- wince的初学总结
- ARM 启动过程
- [工具使用]Outlook 窗体和模板
- 人月神话读书笔记
- 估计这个问题应该被问过无数次了,但还是不懂~~~如何编写swap(int a,int b)
- MTK平台手机音量参数的调整方法
- c# 操作mssql数据库 含有带参数sql语句运行
- 从IT程序语言的发展历史看 SOA