目录

获取当前日期的函数和获取当前时间的函数

CURDATE()CURRENT_DATE()函数获取当前日期;CURTIME()CURRENT_TIME()函数获取当前时间。
mysql> SELECT CURDATE(), CURRENT_DATE(), CURTIME(), CURRENT_TIME();
+------------+----------------+-----------+----------------+
| CURDATE() | CURRENT_DATE() | CURTIME() | CURRENT_TIME() |
+------------+----------------+-----------+----------------+
| 2016-07-19 | 2016-07-19 | 13:46:18 | 13:46:18 |
+------------+----------------+-----------+----------------+

获取当前日期和时间的函数

NOW()函数获取当前日期和时间。
mysql> SELECT NOW();
+---------------------+
| NOW() |
+---------------------+
| 2016-07-19 13:54:08 |
+---------------------+

获取月份的函数

MONTH(d)函数返回日期d中的月份值 ,其取值范围是1~12
mysql> SELECT NOW(), MONTH(NOW());
+---------------------+--------------+
| NOW() | MONTH(NOW()) |
+---------------------+--------------+
| 2016-07-21 13:48:47 | 7 |
+---------------------+--------------+
MONTHNAME(d)函数返回日期d中月份的英文名称,如January,February等
mysql> SELECT NOW(), MONTHNAME(NOW());
+---------------------+------------------+
| NOW() | MONTHNAME(NOW()) |
+---------------------+------------------+
| 2016-07-21 13:50:31 | July |
+---------------------+------------------+

获取星期的函数

DAYNAME(d)函数返回日期d是星期几,显示其英文名,如Monday,Tuesday等
mysql> SELECT NOW(), DAYNAME(NOW());
+---------------------+----------------+
| NOW() | DAYNAME(NOW()) |
+---------------------+----------------+
| 2016-07-21 13:52:52 | Thursday |
+---------------------+----------------+
DAYOFWEEK(d)函数返回日期d是星期几,1表示星期天,2表示星期一,依次类推
mysql> SELECT NOW(), DAYOFWEEK(NOW());
+---------------------+------------------+
| NOW() | DAYOFWEEK(NOW()) |
+---------------------+------------------+
| 2016-07-21 13:57:05 | 5 |
+---------------------+------------------+
WEEKDAY(d)函数返回日期d是星期几,0表示星期一,1表示星期2,依次类推
mysql> SELECT NOW(), WEEKDAY(NOW());
+---------------------+----------------+
| NOW() | WEEKDAY(NOW()) |
+---------------------+----------------+
| 2016-07-21 13:59:01 | 3 |
+---------------------+----------------+

获取星期数的函数

WEEK(d)函数和WEEKOFYEAR(d)函数都是计算日期d是本年的第几个星期,返回值范围是1~53
mysql> SELECT NOW(), WEEK(NOW()), WEEKOFYEAR(NOW());
+---------------------+-------------+-------------------+
| NOW() | WEEK(NOW()) | WEEKOFYEAR(NOW()) |
+---------------------+-------------+-------------------+
| 2016-07-21 14:03:17 | 29 | 29 |
+---------------------+-------------+-------------------+

获取天数的函数

DAYOFYEAR(d)函数返回日期d是本年的第几天
mysql> SELECT NOW(), DAYOFYEAR(NOW());
+---------------------+------------------+
| NOW() | DAYOFYEAR(NOW()) |
+---------------------+------------------+
| 2016-07-21 14:05:10 | 203 |
+---------------------+------------------+
DAYOFMONTH(d)函数返回日期d是本月的第几天
mysql> SELECT NOW(), DAYOFMONTH(NOW());
+---------------------+-------------------+
| NOW() | DAYOFMONTH(NOW()) |
+---------------------+-------------------+
| 2016-07-21 14:06:06 | 21 |
+---------------------+-------------------+

获取年份、季度、小时、分钟和秒数的函数

YEAR(d)函数返回日期d中的年份值;QUARTER(d)函数返回日期d是本年的第几个季度,值的范围是1~4;HOUR(t)函数返回时间t中的小时值;MINUTE(t)函数返回时间t中的分钟值;SECOND(t)函数返回时间t中的秒数。

mysql> SELECT NOW(), YEAR(NOW()), QUARTER(NOW()), HOUR(NOW()), MINUTE(NOW()), SECOND(NOW());
+---------------------+-------------+----------------+-------------+---------------+---------------+
| NOW() | YEAR(NOW()) | QUARTER(NOW()) | HOUR(NOW()) | MINUTE(NOW()) | SECOND(NOW()) |
+---------------------+-------------+----------------+-------------+---------------+---------------+
| 2016-07-21 14:10:49 | 2016 | 3 | 14 | 10 | 49 |
+---------------------+-------------+----------------+-------------+---------------+---------------+

计算日期和时间函数

TO_DAYS(d)函数计算日期d与0000年1月1日的天数
mysql> SELECT NOW(), TO_DAYS(NOW());
+---------------------+----------------+
| NOW() | TO_DAYS(NOW()) |
+---------------------+----------------+
| 2016-07-19 14:03:59 | 736529 |
+---------------------+----------------+
FROM_DAYS(n)函数计算从0000年1月1日开始n天后的日期
mysql> SELECT FROM_DAYS(736529);
+-------------------+
| FROM_DAYS(736529) |
+-------------------+
| 2016-07-19 |
+-------------------+
DATEDIFF(d1, d2)函数计算日期d1与d2之间相隔的天数
mysql> SELECT CURDATE(), DATEDIFF(CURDATE(), '2016-07-23');
+------------+-----------------------------------+
| CURDATE() | DATEDIFF(CURDATE(), '2016-07-23') |
+------------+-----------------------------------+
| 2016-07-21 | -2 |
+------------+-----------------------------------+
ADDDATE(d, n)函数返回起始日期d加上n天后的日期
mysql> SELECT CURDATE(), ADDDATE(CURDATE(), 2);
+------------+-----------------------+
| CURDATE() | ADDDATE(CURDATE(), 2) |
+------------+-----------------------+
| 2016-07-21 | 2016-07-23 |
+------------+-----------------------+
SUBDATE(d, n)函数返回起始日期d减去n天后的日期
mysql> SELECT CURDATE(), SUBDATE(CURDATE(), 2);
+------------+-----------------------+
| CURDATE() | SUBDATE(CURDATE(), 2) |
+------------+-----------------------+
| 2016-07-21 | 2016-07-19 |
+------------+-----------------------+
ADDTIME(t, n)函数返回起始时间t加上n秒后的时间
mysql> SELECT CURTIME(), ADDTIME(CURTIME(), 50);
+-----------+------------------------+
| CURTIME() | ADDTIME(CURTIME(), 50) |
+-----------+------------------------+
| 09:02:18 | 09:03:08 |
+-----------+------------------------+

注:实际操作中,当t >= 60时,ADDTIME(t, n)函数返回NULL

SUBTIME(t, n)函数返回起始时间t减去n秒后的时间
mysql> SELECT CURTIME(), SUBTIME(CURTIME(), 10);
+-----------+------------------------+
| CURTIME() | SUBTIME(CURTIME(), 10) |
+-----------+------------------------+
| 09:06:25 | 09:06:15 |
+-----------+------------------------+

注:实际操作中,当t >= 60时,SUBTIME(t, n)函数返回NULL

ADDDATE(d, INTERVAL expr type)DATE_ADD(d, INTERVAL expr type)返回起始日期d加上一个时间段后的日期
  • expr:时间段长度的表达式。
  • type:日期间隔类型。

日期间隔类型:

类型 含义 expr 表达式的形式
YEAR YY
MONTH MM
DAY DD
HOUR hh
MINUTE mm
SECOND ss
YEAR_MONTH 年和月 YY 和 MM 之间用任意符号隔开
DAY_HOUR 日和小时 DD 和 hh 之间用任意符号隔开
DAY_MINUTE 日和分钟 DD 和 mm 之间用任意符号隔开
DAY_SECOND 日和秒 DD 和 ss 之间用任意符号隔开
HOUR_MINUTE 时和分 hh 和 mm 之间用任意符号隔开
HOUR_SECOND 时和秒 hh 和 ss 之间用任意符号隔开
MINUTE_SECOND 分和秒 mm 和 ss 之间用任意符号隔开
mysql> SELECT NOW(), ADDDATE(NOW(), INTERVAL 1 MONTH);
+---------------------+----------------------------------+
| NOW() | ADDDATE(NOW(), INTERVAL 1 MONTH) |
+---------------------+----------------------------------+
| 2016-07-21 11:46:33 | 2016-08-21 11:46:33 |
+---------------------+----------------------------------+
SUBDATE(d, INTERVAL expr type)函数返回起始日期d减去一个时间段后的日期
mysql> SELECT NOW(), SUBDATE(NOW(), INTERVAL 1 MONTH);
+---------------------+----------------------------------+
| NOW() | SUBDATE(NOW(), INTERVAL 1 MONTH) |
+---------------------+----------------------------------+
| 2016-07-21 11:49:42 | 2016-06-21 11:49:42 |
+---------------------+----------------------------------+

将日期和时间格式化的函数

DATE_FORMAT(d, f)函数按照表达式f的要求显示日期d

日期时间格式:

符号 含义 取值示例
%Y 以4位数字表示年份 2008,2009等
%y 以2位数字表示年份 98,99等
%m 以2位数字表示月份 01,02等
%c 以数字表示月份 1,2等
%M 月份的英文名 January,February等
%b 月份的英文缩写 Jan,Feb等
%U 表示星期数,其中 Sunday 是星期的第一天 00~52
%u 表示星期数,其中 Monday 是星期的第一天 00~52
%j 以3位数字表示年中的天数 001~366
%d 以2位数字表示月中的几号 01~31
%e 以数字表示月中的几号 1~31
%D 以英文后缀表示月中的几号 1st,2nd等
%w 以数字的形式表示星期几 0表示Sunday,1表示Monday
%W 星期几的英文名 Monday,... , Sunday
%a 星期几的英文缩写 Mon, ... , Sun
%T 24小时制的时间形式 00:00:00~23:59:59
%r 12小时制的时间形式 12:00:00AM~11:59:59PM
%p 上午或下午 AM或PM
%k 以数字表示24小时 0,1,...,23
%l 以数字表示12小时 0,1,...,12
%H 以2位数表示24小时 00,01,...,23
%h,%I 以2位数表示12小时 00,01,...,12
%i 以2位数表示分 00~59
%S,%s 以2位数表示秒 00~59
%% 标识符%
mysql> SELECT NOW(), DATE_FORMAT(NOW(), '%Y-%M-%d %H:%i:%s');
+---------------------+-----------------------------------------+
| NOW() | DATE_FORMAT(NOW(), '%Y-%M-%d %H:%i:%s') |
+---------------------+-----------------------------------------+
| 2016-07-21 13:33:12 | 2016-July-21 13:33:12 |
+---------------------+-----------------------------------------+

MySQL 笔记 —— 日期和时间函数的更多相关文章

  1. MySQL数据库—日期与时间函数

    一. 日期和时间函数 函数的概念:按指定格式输入参数,返回正确结果的运算单元 1. 返回当前日期:curdate() current_date() current_date()+0可以将当前日期转换为 ...

  2. mysql 的日期和时间函数

    执行函数方式 select 函数  函数名称 函   数 功   能 CURDATE() 获取当前日期 CURTIME() 获取当前时间 NOW() 获取当前的日期和时间 UNIX_TIMESTAMP ...

  3. MySql日期与时间函数

    select DATE_FORMAT(date_sub(current_date(), interval 1 day), '%Y-%m-%d') -- 2018-05-29(昨天) select DA ...

  4. 转)MySQL日期与时间函数

    -- MySQL日期时间处理函数 -- 当前日期:2017-05-12(突然发现今天512,是不是会拉防空警报) SELECT NOW() FROM DUAL;-- 当前日期时间:2017-05-12 ...

  5. MySQL日期和时间函数汇总

    本文基于MySQL8.0 本文介绍MySQL关于日期和时间操作的函数. 日期和时间函数 函数 描述 ADDDATE() 给日期值添加时间值 ADDTIME() 添加time CONVERT_TZ() ...

  6. sql的日期和时间函数–date_format

    Mysql的日期和时间函数–date_format   DATE_FORMAT(date,format)依照 format 字符串格式化 date 值.下面的修饰符可被用于 format 字符串中:修 ...

  7. MYSQL学习笔记三:日期和时间函数

    MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...

  8. MySQL数据库9 - 日期与时间函数

    一 日期和时间函数 函数的概念:按指定格式输入参数,返回正确结果的运算单元 1. 返回当前日期:curdate() current_date() current_date()+0可以将当前日期转换为数 ...

  9. MySQL中的日期和时间函数

    常用日期函数如下: 函   数 功   能 CURDATE() 获取当前日期 CURTIME() 获取当前时间 NOW() 获取当前的日期和时间 UNIX_TIMESTAMP(date) 获取日期的U ...

随机推荐

  1. JS自动化测试 单元测试之Qunit

    前言 因为公司开发了一套javascript SDK需要测试,在网上找了很久,找到了JQuery团队开发的QUnit,和基于JUnit的JsUnit,还有一些还没有看,先讲讲QUnit吧 下载 登录J ...

  2. 2.2 LINQ中使用from子句指定数据源

    数据源是LINQ查询中必不可少的元素,数据源是实现泛型接口IEnumerable<T>或IQueryable<T>的类对象. 可以将IEnumerable<T>简单 ...

  3. css-fixed兼容写法

    解决IE6中fixed闪动问题(效果稍微好一点,不能完全解决闪动问题) *{background-image:url(about:blank);background-attachment:fixed; ...

  4. oracle中sql语句的优化

    oracle中sql语句的优化 一.执行顺序及优化细则 1.表名顺序优化 (1) 基础表放下面,当两表进行关联时数据量少的表的表名放右边表或视图: Student_info   (30000条数据)D ...

  5. DIP、IoC、DI以及IoC容器

    深入理解DIP.IoC.DI以及IoC容器 摘要 面向对象设计(OOD)有助于我们开发出高性能.易扩展以及易复用的程序.其中,OOD有一个重要的思想那就是依赖倒置原则(DIP),并由此引申出IoC.D ...

  6. ORACLE总结系列1--network文件夹里的admin的三个文件信息

    sqlnet.ora 作用类似于linux或者其他unix的 nsswitch.conf文件,通过这个文件来决定怎么样找一个连接中出现的连接字符串(connect descriptor) 假如sqln ...

  7. JS代码放在head和body中的区别分析

    最近一直在忙工作,没有时间来写博客了,不过今天做网站的时候碰到一个问题就是JS脚本存放的位置不同其效果不同.起初我没在意这个问题,后来一直解决不了,通过上网与查资料问同事,终于我明白了,原来我碰到了这 ...

  8. Java字符串转换为日期和时间比较大小

    字符串转换为时间: String data = "2014/7/11"; SimpleDateFormat dfs = new SimpleDateFormat("yyy ...

  9. EPROCESS KPROCESS PEB

    EPROCESS KPROCESS PEB <寒江独钓>内核学习笔记(2)     在学习笔记(1)中,我们学习了IRP的数据结构的相关知识,接下来我们继续来学习内核中很重要的另一批数据结 ...

  10. CentOS6.8使用源码安装Git

    一.安装git所需的依赖 sudo yum groupinstall "Development Tools" sudo yum install gettext-devel open ...