一、MySQL 获得当前日期时间 函数 
1.1 获得当前日期+时间(date + time)函数:now()

mysql> select now();
+---------------------+
| now()              |
+---------------------+
| 2008-08-08 22:20:46 |
+---------------------+

除了 now() 函数能获得当前的日期时间外,MySQL 中还有下面的函数:

current_timestamp()
,current_timestamp
,localtime()
,localtime
,localtimestamp    -- (v4.0.6)
,localtimestamp()  -- (v4.0.6)

这些日期时间函数,都等同于 now()。鉴于 now() 函数简短易记,建议总是使用 now() 来替代上面列出的函数。

1.2 获得当前日期+时间(date + time)函数:sysdate() 
sysdate() 日期时间函数跟 now() 类似,
不同之处在于:now() 在执行开始时值就得到了, sysdate() 在函数执行时动态得到值。看下面的例子就明白了: 
mysql> select now(), sleep(3), now();
+---------------------+----------+---------------------+
| now()              | sleep(3) | now()              |
+---------------------+----------+---------------------+
| 2008-08-08 22:28:21 |        0 | 2008-08-08 22:28:21 |
+---------------------+----------+---------------------+

mysql> select sysdate(), sleep(3), sysdate();
+---------------------+----------+---------------------+
| sysdate()          | sleep(3) | sysdate()          |
+---------------------+----------+---------------------+
| 2016-08-08 22:28:41 |        0 | 2016-08-08 22:28:44 |
+---------------------+----------+---------------------+
可以看到,虽然中途 sleep 3 秒,
但 now() 函数两次的时间值是相同的; sysdate() 函数两次得到的时间值相差 3 秒。
MySQL Manual 中是这样描述 sysdate() 的:Return the time at which the function executes。 
sysdate() 日期时间函数,一般情况下很少用到。

2. 获得当前日期(date)函数:curdate() 
mysql> select curdate();
+------------+
| curdate()  |
+------------+
| 2008-08-08 |
+------------+
其中,下面的两个日期函数等同于 curdate(): 
current_date(),current_date
3. 获得当前时间(time)函数:curtime() 
mysql> select curtime();
+-----------+
| curtime() |
+-----------+
| 22:41:30  |
+-----------+
其中,下面的两个时间函数等同于 curtime(): 
current_time(),current_time

4. 获得当前 UTC 日期时间函数:utc_date(), utc_time(), utc_timestamp() 
mysql> select utc_timestamp(), utc_date(), utc_time(), now()
+---------------------+------------+------------+---------------------+
| utc_timestamp()    | utc_date() | utc_time() | now()              |
+---------------------+------------+------------+---------------------+
| 2008-08-08 14:47:11 | 2008-08-08 | 14:47:11  | 2008-08-08 22:47:11 |
+---------------------+------------+------------+---------------------+
因为我国位于东八时区,所以本地时间 = UTC 时间 + 8 小时。UTC 时间在业务涉及多个国家和地区的时候,非常有用。

http://blog.csdn.net/aidenliu/article/details/5465300

如何采用MySQL内置函数获取指定时间之前的日期呢?

SELECT DATE(createTime) date型
SELECT DATE_FORMAT(createTime, '%Y-%m-%d') varchar类型

下面的一大堆相关介绍,在网上复制过来的:

mySQL中常用日期时间函数:

select something from table_name where DATE_SUB(CURDATE(),INTERVAL 30 DAY) <= date_col; 获取30天前的日期。

select date_sub(now(),interval 1 year); 获取一年前的今天的日期
select date_sub(now(),interval 1 week); 获取一周前的日期
select date_sub(now(),interval 1 month); 获取一个月前的日期

date_sub()函数:
DATE_SUB(date,INTERVAL expr type)

SELECT NOW(),DATE_SUB(NOW(),INTERVAL 1 HOUR) as the_time

select * from xxx where create_time > DATE_SUB(NOW(),INTERVAL 1 HOUR);

DATE_FORMAT(date,format)

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 位

实例

下面的脚本使用 DATE_FORMAT() 函数来显示不同的格式。我们使用 NOW() 来获得当前的日期/时间:

DATE_FORMAT(NOW(),'%b %d %Y %h:%i %p')
DATE_FORMAT(NOW(),'%m-%d-%Y')
DATE_FORMAT(NOW(),'%d %b %y')
DATE_FORMAT(NOW(),'%d %b %Y %T:%f')

结果类似:

Dec 29 2008 11:45 PM
12-29-2008
29 Dec 08
29 Dec 2008 16:25:46.635

select UNIX_TIMESTAMP('2011-05-31 23:59:59');
select from_unixtime(1306771200);

SELECT NOW();
select from_unixtime(1399537700);
select UNIX_TIMESTAMP(NOW()) * 1000;

SELECTbegin_time,date_format(from_unixtime((begin_time / 1000)),'%Y-%m-%d'),date_format(from_unixtime((begin_time / 1000)),'%Y-%m-%d %T:%f')
FROMtb_test

**需要注意的是select UNIX_TIMESTAMP(NOW()) 输出的是,java中System.currentTimeMillis()输出的是毫秒,需要先除以1000再使用mysql的函数

mysql与日期相关的函数:

下面的查询选择了所有记录,其date_col的值是在最后30天以内:

mysql> SELECT something FROM table
WHERE TO_DAYS(NOW()) - TO_DAYS(date_col)<= 30;

DAYOFWEEK(date)
返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六)。这些索引值对应于ODBC标准。
mysql> select DAYOFWEEK('1998-02-03');
-> 3

WEEKDAY(date)
返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。
mysql> select WEEKDAY('1997-10-04 22:23:00');
-> 5
mysql> select WEEKDAY('1997-11-05');
-> 2

DAYOFMONTH(date)
返回date的月份中日期,在1到31范围内。
mysql> select DAYOFMONTH('1998-02-03');
-> 3

DAYOFYEAR(date)
返回date在一年中的日数, 在1到366范围内。
mysql> select DAYOFYEAR('1998-02-03');
-> 34

MONTH(date)
返回date的月份,范围1到12。
mysql> select MONTH('1998-02-03');
-> 2

DAYNAME(date)
返回date的星期名字。
mysql> select DAYNAME("1998-02-05");
-> 'Thursday'

MONTHNAME(date)
返回date的月份名字。
mysql> select MONTHNAME("1998-02-05");
-> 'February'

QUARTER(date)
返回date一年中的季度,范围1到4。
mysql> select QUARTER('98-04-01');
-> 2

WEEK(date)  
WEEK(date,first)
对于星期天是一周的第一天的地方,有一个单个参数,返回date的周数,范围在0到52。2个参数形式WEEK()允许你指定星期是否开始于星期天或星期一。如果第二个参数是0,星期从星期天开始,如果第二个参数是1,从星期一开始。

mysql> select WEEK('1998-02-20');
-> 7
mysql> select WEEK('1998-02-20',0);
-> 7
mysql> select WEEK('1998-02-20',1);
-> 8

YEAR(date)
返回date的年份,范围在1000到9999。
mysql> select YEAR('98-02-03');
-> 1998

HOUR(time)
返回time的小时,范围是0到23。
mysql> select HOUR('10:05:03');
-> 10

MINUTE(time)
返回time的分钟,范围是0到59。
mysql> select MINUTE('98-02-03 10:05:03');
-> 5

SECOND(time)
回来time的秒数,范围是0到59。
mysql> select SECOND('10:05:03');
-> 3

http://blog.csdn.net/amber_room/article/details/7024896

MySQL日期 专题相关推荐

  1. mysql日期时间函数

    MySQL 日期跟时间函数(一) 作者: Mr.Zhang MySQL 日期跟时间的样式 在MySQL 中有很多有用处的日期跟时间函数.我们常常看到许多应用于日期的计算是在代码 方面上进行的,但是其实 ...

  2. Mysql日期时间Extract函数介绍

    MySQL日期时间Extract函数的优点在于可以选取日期时间的各个部分,从年一直到微秒,让我们对MySQL日期时间的处理更为轻松. MySQL 日期时间 Extract(选取)函数. 1. 选取日期 ...

  3. MYSQL日期 字符串 时间戳互转

    平时比较常用的时间.字符串.时间戳之间的互相转换,虽然常用但是几乎每次使用时候都喜欢去搜索一下用法:本文将作为一个笔记,整理一下三者之间的 转换(即:date转字符串.date转时间戳.字符串转dat ...

  4. MYSQL || 的BUG // MYSQL 不同库自增id的问题 //MySQL根据表注释查找对应的表 //hive -mysql 日期比较

    MYSQL 中的|| 与oracle 的concat 含义不同,它的含义是 or delete from table where 1=1 and code ='CW1111' and period_w ...

  5. 「mysql优化专题」你们要的多表查询优化来啦!请查收(4)

    上一篇讲的是单表查询的优化,(本文末有链接).当然,对数据表的多表查询也是必不可少的.本篇内容主要讲解多表联合查询的优化 一.多表查询连接的选择: 相信这内连接,左连接什么的大家都比较熟悉了,当然还有 ...

  6. 「mysql优化专题」90%程序员都会忽略的增删改优化(2)

    前文一篇「mysql优化专题」这大概是一篇最好的mysql优化入门文章(1)让大家知道msql优化,究竟在优化什么,本篇为mysql优化专题的第二篇,主要先从增删改进行优化. 补充知识点:操作数据语句 ...

  7. 【mysql优化专题】本专题终极总结(共12篇)

    本专题目录如下: 一.为什么要进行mysql优化?(重点) 二.增删改优化,多数人都会忽略的优化 三.关于单表查询,可以这么优化 四.关于多表查询,不得不看的优化 五.索引优化(重点中的重点) 六.表 ...

  8. 「mysql优化专题」这大概是一篇最好的mysql优化入门文章(1)

    [mysql优化专题]:本专题全文围绕mysql优化进行全方位讲解,本篇为优化入门篇,让大家知道为什么要优化,究竟在优化什么. 优化,一直是面试最常问的一个问题.因为从优化的角度,优化的思路,完全可以 ...

  9. 「mysql优化专题」高可用性、负载均衡的mysql集群解决方案(12)

    不可避免的是,使用MySQL时随着时间的增长,用户量以及数据量的逐渐增加,访问量更是剧增,最终将会使MySQL达到某个瓶颈,那么MySQL的性能将会大大降低.怎么办?前面已经讲过十一篇优化方案,接下来 ...

  10. mysql日期存到oracle_mysql与oracle的日期/时间函数小结

    前言 本文的日期/时间全部格式化为"2016-01-01 01:01:01"形式: MONITOR_TIME为数据库表字段: 字符串与日期/时间相互转换函数 Oracle 日期/时 ...

最新文章

  1. EntLib 3.1学习笔记(5) : Exception Handling Application Block
  2. usb_get_device_descriptor()
  3. 程序员接私活的途径以及正确方式。
  4. 轻松玩转jquery。
  5. 模拟标准c++中的Rtti
  6. 都是套路:高并发系统的降级特技
  7. 为什么当代人越来越不快乐?
  8. 面试时Android屏幕适配,Android—屏幕适配(面试技巧)
  9. c语言风景日历制作系统,初学,C语言日历制作
  10. spring cloud config的bootstrap.yml与application.proterties的区别
  11. 详解Python GUI版24点游戏制作过程
  12. Vue源码分析 - observer.js
  13. Java011-多线程
  14. 拓端tecdat|R语言使用自组织映射神经网络(SOM)进行客户细分
  15. 苹果电脑的文件怎么复制到移动硬盘,macbook文件怎么拷贝到移动硬盘
  16. 2017年北京邮电大学计算机考研机试试题及答案
  17. thinkphp ajax 跨域请求 Access-Control-Allow-Origin 完美解决
  18. 全网最通俗易懂的爬虫教程
  19. 如何在Ubuntu 22.04使用wine安装windows版本微信
  20. FastDFS和GFS以及NFS的对比

热门文章

  1. POJ1061 青蛙的约会 扩展欧几里得
  2. 2004级C++试题及答案
  3. linux 设置tomcat快捷启动方式
  4. python编程练习:漏洞百出的四则运算器
  5. 一些常用的前端基础操作
  6. iOS之UI--Quartz2D的入门应用--重绘下载圆形进度条
  7. 解决windows下的mysql匿名登陆无法使用mysql数据库的问题
  8. 在Unity中添加图标
  9. HDU 3622 Bomb Game
  10. 用C#写XML类型的配置文件: