日期和时间函数

可能的需求:

  当前时间是多少、下个月的今天是星期几、统计截止到当前日期前 3 天的收入总和……

上述需求就需要使用日期和时间函数来实现:

MySQL服务器中的三种时区设置:

  ①系统时区---保存在系统变量system_time_zone

  ②服务器时区---保存在全局系统变量global.time_zone

  ③每个客户端连接的时区---保存在会话变量session.time_zone

注意:

  客户端时区的设置会影响一些日期函数返回值的显示,例如:now()、curtime()、curdate(),也影响timestamp列值的显示。

  默认情况下,客户端和服务器的时区相同,其值为SYSTEM,表示使用系统时区。

mysql> select @@global.time_zone,@@session.time_zone;
+--------------------+---------------------+
| @@global.time_zone | @@session.time_zone |
+--------------------+---------------------+
| SYSTEM | SYSTEM |
+--------------------+---------------------+
row in set (0.00 sec) mysql> show variables like 'system_time_zone';
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| system_time_zone | CST |
+------------------+-------+
row in set (0.28 sec)

1、NOW([fsp]):返回服务器的当前日期和时间(fsp指定小数秒的精度,取值0--6)

格式:

  ‘YYYY-MM-DD HH:MM:SS’或者‘YYYYMMDDHHMMSS’

now()的显示格式是‘YYYY-MM-DD HH:MM:SS’
now()+0的显示格式是‘YYYYMMDDHHMMSS’

mysql> select now();
+---------------------+
| now() |
+---------------------+
| -- :: |
+---------------------+ mysql> select now()+;
+----------------+
| now()+ |
+----------------+
| |
+----------------+

 mysql> select now(6);  //指定小数秒的精度
 +----------------------------+
 | now(6) |
 +----------------------------+
 | 2017-04-19 19:55:46.658198 |
 +----------------------------+

now()函数的同义词有:CURRENT_TIMESTAMP 、 CURRENT_TIMESTAMP()、LOCALTIMESTAMP 、 LOCALTIMESTAMP()、LOCALTIME 、 LOCALTIME()

注意:

  SYSDATE( ):返回服务器的当前日期和时间

与now的不同点:(一般使用NOW而不用SYSDATE)

  ①SYSDATE()返回的是函数执行时的时间

  ②now()返回的是语句执行时的时间

mysql> select now(),sleep(),now();
+---------------------+----------+---------------------+
| now() | sleep() | now() |
+---------------------+----------+---------------------+
| -- 20:01:39 | | -- 20:01:39 |
+---------------------+----------+---------------------+
row in set (2.00 sec) mysql> select sysdate(),sleep(),sysdate();
+---------------------+----------+---------------------+
| sysdate() | sleep() | sysdate() |
+---------------------+----------+---------------------+
| -- 20:02:01 | | -- 20:02:03 |
+---------------------+----------+---------------------+
row in set (2.05 sec)

2、CURTIME([fsp]):返回当前时间,只包含时分秒(fsp指定小数秒的精度,取值0--6)

格式:

  ‘YYYY-MM-DD HH:MM:SS’或者‘YYYYMMDDHHMMSS’

mysql> select curtime(),curtime();
+-----------+-------------+
| curtime() | curtime() |
+-----------+-------------+
| :: | ::23.90 |
+-----------+-------------+

同义词有:CURRENT_TIME 、 CURRENT_TIME()

3、CURDATE():返回当前日期,只包含年月日

格式:

  ‘YYYY-MM-DD’或者‘YYYYMMDD’

mysql> select curdate(),curdate()+;
+------------+-------------+
| curdate() | curdate()+ |
+------------+-------------+
| -- | |
+------------+-------------+ mysql> select curdate(),curdate()+;
+------------+-------------+
| curdate() | curdate()+ |
+------------+-------------+
| -- | |
+------------+-------------+

同义词有: CURRENT_DATE 、CURRENT_DATE()

4、TIMEDIFF(expr1, expr2):返回两个日期相减(expr1 − expr2 )相差的时间数(两个参数类型必须相同)

mysql> select timediff('18:32:59','');
+------------------------------+
| timediff('18:32:59','') |
+------------------------------+
| :: |
+------------------------------+ mysql> select timediff('18:32:59','2017-1-1 60000');
+---------------------------------------+
| timediff('18:32:59','2017-1-1 60000') |
+---------------------------------------+
| NULL |
+---------------------------------------+

DATEDIFF(expr1, expr2):返回两个日期相减(expr1 − expr2 )相差的天数

mysql> select datediff('2017-3-24 18:32:59','2016-9-1');
+-------------------------------------------+
| datediff('2017-3-24 18:32:59','2016-9-1') |
+-------------------------------------------+
| |
+-------------------------------------------+

5、日期时间运算函数:分别为给定的日期date加上(add)或减去(sub)一个时间间隔值expr

格式:

  DATE_ADD(date, INTERVAL  expr  unit);

  DATE_SUB(date, INTERVAL  expr  unit);

interval是间隔类型关键字

expr是一个表达式,对应后面的类型

unit是时间间隔的单位(间隔类型)(20个),如下:

HOUR

小时

MINUTE

SECOND

MICROSECOND

毫秒

YEAR

MONTH

DAY

WEEK

QUARTER

YEAR_MONTH

年和月

DAY_HOUR

日和小时

DAY_MINUTE

日和分钟

DAY_ SECOND

日和秒

HOUR_MINUTE

小时和分

HOUR_SECOND

小时和秒

MINUTE_SECOND

分钟和秒

mysql> select now(),date_add(now(),interval  day);  #加一天
+---------------------+--------------------------------+
| now() | date_add(now(),interval day) |
+---------------------+--------------------------------+
| -- :: | -- :: |
+---------------------+--------------------------------+ mysql> SELECT date_sub('2005-01-01 00:00:00',INTERVAL '1 1:1:1' DAY_SECOND);  #减1天1小时1分1秒
+---------------------------------------------------------------+
| date_sub('2005-01-01 00:00:00',INTERVAL '1 1:1:1' DAY_SECOND) |
+---------------------------------------------------------------+
| -- :: |
+---------------------------------------------------------------+

不使用函数,也可以写表达式进行日期的加减:

  date  + INTERVAL  expr  unit

  date  - INTERVAL  expr  unit

mysql> SELECT '2008-12-31 23:59:59' + INTERVAL  SECOND;
+-------------------------------------------+
| '2008-12-31 23:59:59' + INTERVAL SECOND |
+-------------------------------------------+
| -- :: |
+-------------------------------------------+
row in set (0.00 sec) mysql> SELECT '2005-01-01' - INTERVAL SECOND;
+----------------------------------+
| '2005-01-01' - INTERVAL SECOND |
+----------------------------------+
| -- :: |
+----------------------------------+
row in set (0.00 sec)

6、选取日期时间的各个部分:日期、时间、年、季度、月、日、小时、分钟、秒、微秒(常用)

SELECT now(),date(now()); -- 日期

SELECT now(),time(now()); -- 时间

SELECT now(),year(now()); -- 年

SELECT now(),quarter(now()); -- 季度

SELECT now(),month(now()); -- 月

SELECT now(),week(now()); -- 周

SELECT now(),day(now()); -- 日

SELECT now(),hour(now()); -- 小时

SELECT now(),minute(now()); -- 分钟

SELECT now(),second(now()); -- 秒

SELECT now(),microsecond(now()); -- 微秒

EXTRACT(unit  FROM  date):从日期中抽取出某个单独的部分或组合

SELECT now(),extract(YEAR FROM now()); -- 年

SELECT now(),extract(QUARTER FROM now()); -- 季度

SELECT now(),extract(MONTH FROM now()); -- 月

SELECT now(),extract(WEEK FROM now()); -- 周

SELECT now(),extract(DAY FROM now()); -- 日

SELECT now(),extract(HOUR FROM now()); -- 小时

SELECT now(),extract(MINUTE FROM now()); -- 分钟

SELECT now(),extract(SECOND FROM now()); -- 秒

SELECT now(),extract(YEAR_MONTH FROM now()); -- 年月

SELECT now(),extract(HOUR_MINUTE FROM now()); -- 时分

7、个性化显示时间日期

  dayofweek(date)

  dayofmonth(date)

  dayofyear(date)

##分别返回日期在一周、一月、一年中是第几天

mysql> SELECT now(),dayofweek(now());
+---------------------+------------------+
| now() | dayofweek(now()) |
+---------------------+------------------+
| -- :: | |
+---------------------+------------------+
row in set (0.00 sec) mysql> SELECT now(),dayofmonth(now());
+---------------------+-------------------+
| now() | dayofmonth(now()) |
+---------------------+-------------------+
| -- :: | |
+---------------------+-------------------+
row in set (0.03 sec) mysql> select now(),dayofyear(now());
+---------------------+------------------+
| now() | dayofyear(now()) |
+---------------------+------------------+
| -- :: | |
+---------------------+------------------+
row in set (0.00 sec)

  

  dayname()

  monthname()

##分别返回日期的星期和月份名称

名称是中文or英文的由系统变量lc_time_names控制(默认值是'en_US')

mysql> show variables like 'lc_time_names';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| lc_time_names | en_US |
+---------------+-------+
row in set (0.00 sec) mysql> select dayname(now()),monthname(now());
+----------------+------------------+
| dayname(now()) | monthname(now()) |
+----------------+------------------+
| Wednesday | April |
+----------------+------------------+
row in set (0.00 sec) mysql> set lc_time_names='zh_CN';
Query OK, rows affected (0.00 sec) mysql> select dayname(now()),monthname(now());
+----------------+------------------+
| dayname(now()) | monthname(now()) |
+----------------+------------------+
| 星期三 | 四月 |
+----------------+------------------+
row in set (0.00 sec)

MySQL最常用日期时间函数的更多相关文章

  1. MYSQL 中常用日期时间函数使用

    MySQL Date 函数 下面的表格列出了 MySQL 中最重要的内建日期函数: 函数 描述 NOW() 返回当前的日期和时间 CURDATE() 返回当前的日期 CURTIME() 返回当前的时间 ...

  2. MySQL常用日期时间函数

    日期和时间函数: MySQL服务器中的三种时区设置: ①系统时区---保存在系统变量system_time_zone ②服务器时区---保存在全局系统变量global.time_zone ③每个客户端 ...

  3. MySQL基础之 日期时间函数

    基础日期函数和时间函数 1.CURDATE()函数:返回当前只带有年月日格式的日期 2.CURTIME()函数:返回当前只带有时分秒格式的时间 3.NOW()函数:返回当前日期和时间 4.UNIX_T ...

  4. [转载]C# 常用日期时间函数(老用不熟)

    原博地址:http://www.jb51.net/article/20181.htm --DateTime 数字型 System.DateTime currentTime=new System.Dat ...

  5. MySQL一些常用的时间函数

    https://my.oschina.net/sallency/blog/470370

  6. Mysql学习笔记(五)数学与日期时间函数

    学习内容: 1.数学函数 2.日期时间函数 这些函数都是很常用的函数...在这里进行简单的介绍... 数学函数: mysql); //取绝对值函数 这个函数可安全地使用于 BIGINT 值. mysq ...

  7. mysql与oracle的日期/时间函数小结

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

  8. MySQL日期时间函数大全(转)

    MySQL日期时间函数大全 DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK('1 ...

  9. 【转】MySQL日期时间函数大全

    MySQL日期时间函数大全 1.DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK( ...

随机推荐

  1. 用虚拟机安装Linux系统的过程

    1.打开VMware->点击File->点击New Virtual Machine.. 2.我们选择Custom并点击Next 3.保持默认然后点next 4.选择图中所示内容,点Next ...

  2. java之JDK的环境变量配置

    JDK是什么? JDK是整个java开发的核心,它包含了JAVA的运行环境,JAVA工具和JAVA基础的类库. JDK包含的基本组件包括 java –--------> 运行编译后的java程序 ...

  3. RabbitMQ-从基础到实战(1)— Hello RabbitMQ

    转载请注明出处 1.简介 本篇博文介绍了在windows平台下安装RabbitMQ Server端,并用JAVA代码实现收发消息 2.安装RabbitMQ RabbitMQ是用Erlang开发的,所以 ...

  4. 2017Java技术预备作业1501黄学超

    阅读邹欣老师的博客,谈谈你期望的师生关系是什么样的? 我觉得师生关系应当是亲密无间,课上老师讲解学生配合,课下师生交流启发思考. 你有什么技能(学习,棋类,球类,乐器,艺术,游戏,......)比大多 ...

  5. C++基础——C面向过程与C++面向对象编程01_圆面积求解

    #include "iostream";//包含C++的头文件using namespace std;//使用命名空间std标准的命名空间(在这个命名空间中定义了很多标准定义)vo ...

  6. linux CentOS6.5 安装SVN & 可视化管理工具iF.SVNAdmin

    转:http://tanghenxin.lofter.com/post/1cc667b3_5ac50dc 实际系统环境: CentOS 6.5 x64 一.安装Apache 通常系统都已经装好了,但我 ...

  7. C# .NET 逻辑层的框架设计

    前述:在我的了解中,一个大项目的逻辑层是不可捉摸的,对于不同项目或场景都是不同的逻辑.先说明,我的想法是对逻辑层类结构,以及如何操作逻辑的方法进行抽象的封装.并且考虑将不同类,或者不同程序集中的逻辑方 ...

  8. 一文让你从此告别HTTP乱码(一)Request篇

    #circle { background-color: #8fcbec; border: 3px } 概述 开发Web项目的过程中,经常遇到浏览器中显示的内容乱码,或者服务器获取浏览器请求参数时乱码的 ...

  9. Moving to Express 4

    http://expressjs.com/guide/migrating-4.html Moving to Express 4 Overview Express 4 is a breaking cha ...

  10. 面向对象编程思想(前传)--你必须知道的javascript

    在写面向对象编程思想-设计模式中的js部分的时候发现很多基础知识不了解的话,是很难真正理解和读懂js面向对象的代码.为此,在这里先快速补上.然后继续我们的面向对象编程思想-设计模式. 什么是鸭子类型 ...