MySQL中时间函数操作大全
作者:桐花思雨 发布时间:2024-01-14 19:45:11
1. 获取系统当前时间
MySQL
版本为 5.7
,详细的时间函数可以参考 MySQL
官方文档 在这里
1.1. 获取 YYYY-MM-DD HH:mm:ss
SELECT NOW(),CURRENT_TIMESTAMP(),SYSDATE(),CURRENT_TIMESTAMP;
NOW()
返回当前日期和时间CURRENT_TIMESTAMP(),CURRENT_TIMESTAMP
都是NOW()
函数的同义词NOW()
在执行开始时值就得到了SYSDATE()
返回函数执行的时间,一般情况下很少用到
1.2. 获取 YYYY-MM-DD
SELECT CURRENT_DATE,CURRENT_DATE(),CURDATE(),DATE(NOW());
CURDATE()
返回当前日期CURRENT_DATE(),CURRENT_DATE
都是CURDATE()
的同义词DATE()
提取日期或日期时间表达式的日期部分
1.3. 获取 HH:mm:ss
SELECT CURRENT_TIME,CURRENT_TIME(),CURTIME(),TIME(NOW());
CURTIME()
返回当前时间CURRENT_TIME(),CURRENT_TIME
都是CURTIME()
的同义词TIME()
提取传递的表达式的时间部分
2. 时间加减间隔函数
MySQL
中内置函数 DATE_ADD()
和 DATE_SUB()
能对指定的时间进行增加或减少一个指定的时间间隔,语法如下
DATE_ADD(date,INTERVAL expr type)
DATE_SUB(date,INTERVAL expr type)
date
是指定的日期INTERVAL
为关键词expr
是具体的时间间隔type
是时间单位
注意:type
可以是复合型的,比如 YEAR_MONTH
。如果 type
不是复合型的, DATE_ADD()
和 DATE_SUB()
其实可以通用,因为 expr
可以为一个负数。可用的 type
如下表
MICROSECOND | 间隔单位:毫秒 |
SECOND | 间隔单位:秒 |
MINUTE | 间隔单位:分钟 |
HOUR | 间隔单位:小时 |
DAY | 间隔单位:天 |
WEEK | 间隔单位:星期 |
MONTH | 间隔单位:月 |
QUARTER | 间隔单位:季度 |
YEAR | 间隔单位:年 |
SECOND_MICROSECOND | 复合型,间隔单位:秒、毫秒,expr可以用两个值来分别指定秒和毫秒 |
MINUTE_MICROSECOND | 复合型,间隔单位:分、毫秒 |
MINUTE_SECOND | 复合型,间隔单位:分、秒 |
HOUR_MICROSECOND | 复合型,间隔单位:小时、毫秒 |
HOUR_SECOND | 复合型,间隔单位:小时、秒 |
HOUR_MINUTE | 复合型,间隔单位:小时分 |
DAY_MICROSECOND | 复合型,间隔单位:天、毫秒 |
DAY_SECOND | 复合型,间隔单位:天、秒 |
DAY_MINUTE | 复合型,间隔单位:天、分 |
DAY_HOUR | 复合型,间隔单位:天、小时 |
YEAR_MONTH | 复合型,间隔单位:年、月 |
2.1. DATETIME 类型的加减
-- 给当前的时间日期增加一个月
SELECT DATE_ADD(NOW(),INTERVAL 1 MONTH), NOW();
-- 给当前的时间日期减少一个月
SELECT DATE_SUB(NOW(),INTERVAL 1 MONTH), NOW();
2.2. DATE 类型的加减
-- 给当前的日期增加 10 天
SELECT DATE_ADD(DATE(NOW()),INTERVAL 10 DAY), DATE(NOW());
-- 给当前的日期减少 10 天
SELECT DATE_SUB(DATE(NOW()),INTERVAL 10 DAY), DATE(NOW());
3. 两个时间的相减
3.1. DATE 类型相减
DATEDIFF(date1, date2)
减去两个日期,比较的是天数,与时间无关 date1 - date2
SELECT DATEDIFF('2013-01-13','2012-10-01');
SELECT DATEDIFF('2013-01-13 13:13:13','2012-10-01 16:16:16');
SELECT DATEDIFF('13:13:13','16:16:16');
3.2. TIMESTAMP 类型
TIMESTAMPDIFF(type, ts1, ts2)
: 根据 type
,计算两个时间 ts2 - ts1
相差多少天、月、年等
SELECT TIMESTAMPDIFF(DAY, '2013-01-13','2012-10-01');
SELECT TIMESTAMPDIFF(MONTH, '2013-01-13 13:13:13','2012-10-01 16:16:16');
SELECT TIMESTAMPDIFF(HOUR, '13:13:13','16:16:16');
MySQL 关于时间函数的官方文档:https://dev.mysql.com/doc/refman/5.7/en/date-and-time-functions.html
附:时间差 datediff()
//计算两个时间的天数差
select datediff("2018-05-10","2018-05-20")
//结果是:-10
时间格式化
select date_format("2018-05-10","%Y/%m/%d") 2018/05/10
来源:https://blog.csdn.net/weixin_38192427/article/details/123365010


猜你喜欢
- 简介Python 的序列(sequence)通常指一个可迭代的容器,容器中可以存放任意类型的元素。列表和元组这两种数据类型是最常被用到的序列
- 一.什么是RedisRedis是一个非关系型数据库,具有很高的存取性能,一般用作缓存数据库,减少正常存储数据库的压力。Redis可以存储键与
- MSSQL2005数据库版本 SQL Server 2005 的各版本之间选择 大多数企业都在三个 SQL Ser
- 前面简单提到了 Python 模拟登录的程序,但是没写清楚,这里再补上一个带注释的 Python 模拟登录的示例程序。简单说一下流程:先用c
- 本文实例讲述了python文件读写操作与linux shell变量命令交互执行的方法。分享给大家供大家参考。具体如下:python对文件的读
- 大家可能有这样的体验,好比在程序里面我明明写了app.run(port=8001),结果程序还是在5000端口输出,我们右键点击py程序,直
- Vue使用Swiper看这一篇就够了此案例实现需求完成swiper动态异步数据下的slide渲染自定义分页器样式解决loop:true设置时
- 安装依赖1)下载安装opencv-2.4.9,并将cv2.pyd拷贝到python安装目录的site-package下2)pip insta
- 1. 下载MySQL Community Server 5.6.35下载地址http://dev.mysql.com/downloads/m
- 效果图如下:Demo演示地址:点击这里主要的JS代码如下:var tbody = document.querySelector('#
- 然后我们在Interactive Python prompt中测试了一下:>>> import subprocess &n
- 卷积核可视化import matplotlib.pyplot as pltimport numpy as npfrom keras impo
- pytorch更新完后合并了Variable与Tensortorch.Tensor()能像Variable一样进行反向传播的更新,返回值为T
- 曾经见过为了让钩子函数的异步代码可以同步执行,而对钩子函数使用async/await,就好像下面的代码:// exp-01export de
- vm.$watch用法: vm.$watch( expOrFn, callback, [options] ) ,返回值为 unwatch 是
- 把下面SQL里的SELECT单独执行,没有问题,但是用来CREATE VIEW 就报错了.CREATE OR REPLA
- 1 查找记录条数 select count(*) from table_name(换成表名)&nbs
- Web应用中大多会提供静态文件服务以便给用户更好的访问体验。静态文件主要包含CSS样式文件,js脚本,图片和字体等。Flask也支持静态文件
- python中的with语句使用于对资源进行访问的场合,保证不管处理过程中是否发生错误或者异常都会执行规定的__exit__(“清理”)操作
- 大家经常用的是Adodb.Stream,但这时就有个缺陷,就是不支持断点续传了。经常看到flashget中是红脸(即不支持断点续传)其实支持