1、NOW
获取当前日期和时间的函数。
语法: NOW()
例如:select NOW();
2、CURDATE
获取当前的日期
语法:CURDATE()
3、CURTIME()
获取当前时间
语法:CURTIME()
4、DATE
获取日期时间或者日期的日期部分
语法:DATE(date)
date 参数是合法的日期表达式。
例如:
5、EXTRACT
获取返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。
语法:EXTRACT(unit FROM date)
date 参数是合法的日期表达式。
unit 参数可以是下列的值: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
例如获取当前年月:select EXTRACT(YEAR_MONTH FROM '2017-01-02 23:11:45') ;
6、DATE_ADD
将日期添加指定的时间间隔。
语法:DATE_ADD(date,INTERVAL expr type)
date 参数是合法的日期表达式。expr 参数是添加的时间间隔。
type 参数可以是下列值: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
例如:select DATE_ADD(now(),INTERVAL 2 DAY); //获取两天后的时间
7、DATE_SUB
将日期减去指定的时间间隔。
语法:DATE_SUB(date,INTERVAL expr type)
date 参数是合法的日期表达式。expr 参数是添加的时间间隔。
type 参数可以是下列值: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
例如:select DATE_SUB(now(),INTERVAL 2 DAY); //获取两天前的时间
8、DATEDIFF
获取两个日期之间的天数。(只有日期部分参与计算)
语法:DATEDIFF(date1,date2)
date1 和 date2 参数是合法的日期或日期/时间表达式。
例如:SELECT DATEDIFF(NOW(),'2008-08-08') AS 北京奥运会多天前;
赶巧算一下我多大了,哎已经23岁半了,岁月不饶人啊,言归正传,这里是dete1-date2的日期部分,所以我查出来的是负数
9、DATEFORMAT
格式化日期时间
语法:DATE_FORMAT(date,format)
date 参数是合法的日期。format 规定日期/时间的输出格式。
格式:描述
%a:缩写星期名
%b:缩写月名
%c:月,数值
%D:带有英文前缀的月中的天
%d:月的天,数值(00-31)
%e:月的天,数值(0-31)
%f:微秒
%H:小时 (00-23)
%h:小时 (01-12)
%I:小时 (01-12)
%i:分钟,数值(00-59)
%j:年的天 (001-366)
%k:小时 (0-23)
%l:小时 (1-12)
%M:月名
%m:月,数值(00-12)
%p:AM 或 PM
%r:时间,12-小时(hh:mm:ss AM 或 PM)
%S:秒(00-59)
%s:秒(00-59)
%T:时间, 24-小时 (hh:mm:ss)
%U:周 (00-53) 星期日是一周的第一天
%u:周 (00-53) 星期一是一周的第一天
%V:周 (01-53) 星期日是一周的第一天,与 %X 使用
%v:周 (01-53) 星期一是一周的第一天,与 %x 使用
%W:星期名
%w:周的天 (0=星期日, 6=星期六)
%X:年,其中的星期日是周的第一天,4 位,与 %V 使用
%x:年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y:年,4 位
%y:年,2 位
数据库对日期进行比较
原则是先把两个日期的格式统一一下,然后把日期字符串转化为日期,最后进行比较
转化为日期的两个时间可以做加减运算得出的结果为天数.
结果*24则得出的是小时数
结果*24*60得出的是分钟数
结果*24*60*60得出的是秒数
ceil((To_date(to_char(sysdate, 'yyyy-MM-dd HH24:mi:ss'),'yyyy-mm-dd hh24-mi-ss') -
To_date(GXSJ, 'yyyy-mm-dd hh24-mi-ss')) * 24 * 60) > 10
计算两个日期相差的分钟数
ceil和floor函数在一些业务数据的时候,有时还是很有用的。
ceil(n) 取大于等于数值n的最小整数;
floor(n)取小于等于数值n的最大整数
select * from up_date where update < to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss') select * from up_date where update <= to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss')
在今天只后:
select * from up_date where update > to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss') select * from up_date where update >= to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss')
精确时间:
select * from up_date where update = to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss')
在某段时间内:
select * from up_date where update between to_date('2007-07-07 00:00:00','yyyy-mm-dd hh24:mi:ss') and to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss') select * from up_date where update < to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss') and update > to_date('2007-07-07 00:00:00','yyyy-mm-dd hh24:mi:ss') select * from up_date where update <= to_date('2007-09-07 00:00:00','yyyy-mm-dd hh24:mi:ss') and update >= to_date('2007-07-07 00:00:00','yyyy-mm-dd hh24:mi:ss')
mysql中日期的比较
select * from student where '2012-02-27 00:00:00' < created_date and '2012-02-29 00:00:00' > created_date
select * from student where UNIX_TIMESTAMP('2012-02-27 00:00:00') < UNIX_TIMESTAMP(created_date) and UNIX_TIMESTAMP('2012-02-29 00:00:00') > UNIX_TIMESTAMP(created_date);
SELECT * FROM student WHERE (UNIX_TIMESTAMP(created_date) - UNIX_TIMESTAMP('2012-02-26 00:00:00') ) >= 0 AND (UNIX_TIMESTAMP(created_date) - UNIX_TIMESTAMP('2012-02-29 00:00:00') ) <= 0
MySql中时间比较的实现
unix_timestamp 函数可以接受一个参数,也可以不使用参数。它的返回值是一个无符号的整数。不使用参数,它返回自1970年1月1日0时0分0秒到现在所经过的秒数,如果使用参数,参数的类型为时间类型或者时间类型的字符串表示,则是从1970-01-01 00:00:00到指定时间所经历的秒数。
有了这个函数,就可以很自然地把时间比较转换为一个无符号整数的比较。
例如,判断一个时间是否在一个区间内
unix_timestamp( time ) between unix_timestamp( 'start ') and unix_timestamp( 'end' )
mysql中多条件判断:
要求日期在2017-12-28,且city这一列的值为Beijing,SQL语句如下:
SELECT * FROM table_name where UNIX_TIMESTAMP(flightDate)=UNIX_TIMESTAMP('2017-12-28') and city='Beijing';
这篇文章主要介绍了Mysql中日期比较大小的方法,需要的朋友可以参考下
假如有个表product有个字段add_time,它的数据类型为datetime,有人可能会这样写sql:
代码如下
1 |
select * from product where add_time = '2013-01-12' |
对于这种语句,如果你存储的格式是YY-mm-dd是这样的,那么OK,如果你存储的格式是:2013-01-12 23:23:56这种格式你就悲剧了,这是你就可以使用DATE()函数用来返回日期的部分,所以这条sql应该如下处理:
代码如下
1 |
select * from product where Date(add_time) = '2013-01-12' |
再来一个,如果你要查询2013年1月份加入的产品呢?
代码如下
1 |
select * from product where date(add_time) between '2013-01-01' and '2013-01-31' |
你还可以这样写:
1 |
select * from product where Year(add_time) = 2013 and Month(add_time) = 1 |
这些你该知道mysql日期函数在对你处理日期比较问题的作用了吧?
其date_col的值是在最后30天以内:
代码如下
1 2 3 |
mysql> SELECT something FROM table WHERE TO_DAYS(NOW()) - TO_DAYS(date_col) <= 30; DAYOFWEEK(date) |
返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六)。这些索引值对应于ODBC标准。
代码如下
1 2 3 |
mysql> select DAYOFWEEK('1998-02-03'); -> 3 WEEKDAY(date) |
返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。
代码如下
1 2 3 4 5 |
mysql> select WEEKDAY('1997-10-04 22:23:00'); -> 5 mysql> select WEEKDAY('1997-11-05'); -> 2 DAYOFMONTH(date) |
返回date的月份中日期,在1到31范围内。
代码如下
1 2 3 |
mysql> select DAYOFMONTH('1998-02-03'); -> 3 DAYOFYEAR(date) |
返回date在一年中的日数, 在1到366范围内。
代码如下
1 2 3 |
mysql> select DAYOFYEAR('1998-02-03'); -> 34 MONTH(date) |
返回date的月份,范围1到12。
代码如下
1 2 3 |
mysql> select MONTH('1998-02-03'); -> 2 DAYNAME(date) |
返回date的星期名字。
代码如下
1 2 3 |
mysql> select DAYNAME("1998-02-05"); -> 'Thursday' MONTHNAME(date) |
返回date的月份名字。
代码如下
1 2 3 |
mysql> select MONTHNAME("1998-02-05"); -> 'February' QUARTER(date) |
返回date一年中的季度,范围1到4。
代码如下
1 2 |
mysql> select QUARTER('98-04-01'); -> 2 |