网站首页 > 基础教程 正文
前两期我们分别学习了Mysql数据库中常见的字符函数和数值函数,那么本期我们一起来学习Mysql数据库中常见的日期时间函数。
ADDDATE(d,n):计算起始日期 d 加上 n 天的日期
实例:
SELECT ADDDATE("2017-06-15", INTERVAL 10 DAY);
返回结果:2017-06-25
ADDTIME(t,n) :时间 t 加上 n 秒的时间
实例:
SELECT ADDTIME('2011-11-11 11:11:11', 5);
返回结果:2011-11-11 11:11:16 (秒)
CURDATE():返回当前日期
实例:
SELECT CURDATE();
返回结果: 2018-09-19
CURRENT_DATE():返回当前日期
实例:
SELECT CURRENT_DATE();
返回结果: 2018-09-19
CURRENT_TIME:返回当前时间
实例:
SELECT CURRENT_TIME();
返回结果: 19:59:02
CURRENT_TIMESTAMP():返回当前日期和时间
实例:
SELECT CURRENT_TIMESTAMP();
返回结果: 2018-09-19 20:57:43
CURTIME():返回当前时间
实例:
SELECT CURTIME();
返回结果: 19:59:02
DATE():从日期或日期时间表达式中提取日期值
实例:
SELECT DATE("2017-06-15");
返回结果: 2017-06-15
DATEDIFF(d1,d2):计算日期 d1返回结果:d2 之间相隔的天数
实例:
SELECT DATEDIFF('2001-01-01','2001-02-02');
返回结果: -32
DATE_ADD(d,INTERVAL expr type) :计算起始日期 d 加上一个时间段后的日期
实例:
SELECT ADDDATE('2011-11-11 11:11:11',1);
返回结果: 2011-11-12 11:11:11 (默认是天)
SELECT ADDDATE('2011-11-11 11:11:11', INTERVAL 5 MINUTE);
返回结果: 2011-11-11 11:16:11 (TYPE的取值与上面那个列出来的函数类似)
DATE_FORMAT(d,f):按表达式 f的要求显示日期 d
实例:
SELECT DATE_FORMAT('2011-11-11 11:11:11','%Y-%m-%d %r');
返回结果: 2011-11-11 11:11:11 AM
DATE_SUB(date,INTERVAL expr type):函数从日期减去指定的时间间隔。
Orders 表中 OrderDate 字段减去 2 天:
实例:
SELECT OrderId,DATE_SUB(OrderDate,INTERVAL 2 DAY) AS OrderPayDate
FROM Orders;
DAY(d):返回日期值 d 的日期部分
实例:
SELECT DAY("2017-06-15");
返回结果: 15
DAYNAME(d) :返回日期 d 是星期几,如 Monday,Tuesday
实例:
SELECT DAYNAME('2011-11-11 11:11:11');
返回结果:Friday
DAYOFMONTH(d) :计算日期 d 是本月的第几天
实例:
SELECT DAYOFMONTH('2011-11-11 11:11:11');
返回结果:11
DAYOFWEEK(d):日期 d 今天是星期几,1 星期日,2 星期一,以此类推
实例:
SELECT DAYOFWEEK('2011-11-11 11:11:11');
返回结果:6
DAYOFYEAR(d):计算日期 d 是本年的第几天
实例:
SELECT DAYOFYEAR('2011-11-11 11:11:11');
返回结果:315
FROM_DAYS(n):计算从 0000 年 1 月 1 日开始 n 天后的日期
实例:
SELECT FROM_DAYS(1111);
返回结果: 0003-01-16
HOUR(t) :返回 t 中的小时值
实例:
SELECT HOUR('1:2:3');
返回结果: 1
LAST_DAY(d) :返回给给定日期的那一月份的最后一天
实例:
SELECT LAST_DAY("2017-06-20");
返回结果: 2017-06-30
LOCALTIME() :返回当前日期和时间
实例:
SELECT LOCALTIME();
返回结果: 2018-09-19 20:57:43
LOCALTIMESTAMP():返回当前日期和时间
实例:
SELECT LOCALTIMESTAMP();
返回结果: 2018-09-19 20:57:43
MAKEDATE(year, day-of-year):基于给定参数年份 year 和所在年中的天数序号 day-of-year 返回一个日期
实例:
SELECT MAKEDATE(2017, 3);
返回结果: 2017-01-03
MAKETIME(hour, minute, second):组合时间,参数分别为小时、分钟、秒
实例:
SELECT MAKETIME(11, 35, 4);
返回结果: 11:35:04
MICROSECOND(date):返回日期参数所对应的微秒数
实例:
SELECT MICROSECOND("2017-06-20 09:34:00.000023");
返回结果: 23
MINUTE(t):返回 t 中的分钟值
实例:
SELECT MINUTE('1:2:3');;
返回结果: 2
MONTHNAME(d):返回日期当中的月份名称,如 November
实例:
SELECT MONTHNAME('2011-11-11 11:11:11');
返回结果: November
MONTH(d):返回日期d中的月份值,1 到 12
实例:
SELECT MONTH('2011-11-11 11:11:11');
返回结果:11
NOW():返回当前日期和时间
实例:
SELECT NOW();
返回结果: 2018-09-19 20:57:43
PERIOD_ADD(period, number):为 年-月 组合日期添加一个时段
实例:
SELECT PERIOD_ADD(201703, 5);
返回结果: 201708
PERIOD_DIFF(period1, period2):返回两个时段之间的月份差值
实例:
SELECT PERIOD_DIFF(201710, 201703);
返回结果: 7
QUARTER(d):返回日期d是第几季节,返回 1 到 4
实例:
SELECT QUARTER('2011-11-11 11:11:11');
返回结果: 4
SECOND(t):返回 t 中的秒钟值
实例:
SELECT SECOND('1:2:3');
返回结果: 3
SEC_TO_TIME(s):将以秒为单位的时间 s 转换为时分秒的格式
实例:
SELECT SEC_TO_TIME(4320);
返回结果: 01:12:00
STR_TO_DATE(string, format_mask):将字符串转变为日期
实例:
SELECT STR_TO_DATE("August 10 2017", "%M %d %Y");
返回结果: 2017-08-10
SUBDATE(d,n):日期 d 减去 n 天后的日期
实例:
SELECT SUBDATE('2011-11-11 11:11:11', 1);
返回结果:2011-11-10 11:11:11 (默认是天)
SUBTIME(t,n):时间 t 减去 n 秒的时间
实例:
SELECT SUBTIME('2011-11-11 11:11:11', 5);
返回结果:2011-11-11 11:11:06 (秒)
SYSDATE():返回当前日期和时间
实例:
SELECT SYSDATE();
返回结果: 2018-09-19 20:57:43
TIME(expression):提取传入表达式的时间部分
实例:
SELECT TIME("19:30:10");
返回结果: 19:30:10
TIME_FORMAT(t,f):按表达式 f 的要求显示时间 t
实例:
SELECT TIME_FORMAT('11:11:11','%r');
返回结果:11:11:11 AM
TIME_TO_SEC(t):将时间 t 转换为秒
实例:
SELECT TIME_TO_SEC('1:12:00');
返回结果: 4320
TIMEDIFF(time1, time2):计算时间差值
实例:
SELECT TIMEDIFF("13:10:11", "13:10:10");
返回结果: 00:00:01
TIMESTAMP(expression, interval):单个参数时,函数返回日期或日期时间表达式;有2个参数时,将参数加和
实例:
SELECT TIMESTAMP("2017-07-23", "13:10:11");
返回结果: 2017-07-23 13:10:11
TO_DAYS(d):计算日期 d 距离 0000 年 1 月 1 日的天数
实例:
SELECT TO_DAYS('0001-01-01 01:01:01');
返回结果: 366
WEEK(d) :计算日期 d 是本年的第几个星期,范围是 0 到 53
实例:
SELECT WEEK('2011-11-11 11:11:11');
返回结果: 45
WEEKDAY(d) :日期 d 是星期几,0 表示星期一,1 表示星期二
实例:
SELECT WEEKDAY("2017-06-15");
返回结果: 3
WEEKOFYEAR(d) :计算日期 d 是本年的第几个星期,范围是 0 到 53
实例:
SELECT WEEKOFYEAR('2011-11-11 11:11:11');
返回结果: 45
YEAR(d):返回年份
实例:
SELECT YEAR("2017-06-15");
返回结果: 2017
YEARWEEK(date, mode):返回年份及第几周(0到53),mode 中 0 表示周天,1表示周一,以此类推
实例:
SELECT YEARWEEK("2017-06-15");
返回结果: 201724
学到这里我们Mysql数据库常见函数就告一段落了,更多Mysql数据库知识等你来学习,我们下期见哦。
PS:获取更多资料,私信我哦~
猜你喜欢
- 2024-11-07 VBA编程,利用DatePart函数获取特定日期
- 2024-11-07 MySQL引起的CPU消耗过大,你会如何优化?
- 2024-11-07 高级数据分析师必备SQL常用处理函数,我觉得收藏是必须的
- 2024-11-07 每日SQL自学知识点(第三天)—lead的窗口函数、datediff函数
- 2024-11-07 mysql与时间有关的查询 mysql与时间有关的查询方法
- 2024-11-07 面试官:如何正确的清理Mysql数据库binlog日志?
- 2024-11-07 数据库丨从MySQL数值隐式转换成了double型的测试点,值得学习
- 2024-11-07 限定Excel数据使用时间,到期自动销毁,这2种方法都能轻松搞定
- 2024-11-07 关于Mysql数据库清理binlog日志命令总结
- 2024-11-07 「MySQL入门」快来看看MySQL函数就是这么简单
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)