MySQL加减间隔时间函数DATE_ADD和DATE_SUB的详解

目录

  • 前言
  • 语法
  • 示例代码
  • 运用

前言

mysql中内置函数date_add 和 date_sub能对指定的时间进行增加或减少一个指定的时间间隔,返回的是一个日期。

语法

添加时间间隔

DATE_ADD(date,INTERVAL expr type)SELECT DATE_add(NOW(),INTERVAL -7 DAY);//获取7天前的日期
SELECT DATE_add(NOW(),INTERVAL  7 DAY);//获取7天后的日期

减少时间间隔

DATE_SUB(date, INTERVAL expr type)SELECT DATE_SUB(NOW(),INTERVAL -7 DAY);//获取7天后的日期
SELECT DATE_SUB(NOW(),INTERVAL  7 DAY);//获取7天前的日期

参数说明

date 操作的时间
INTERVAL为关键词
expr 具体数值
type 时间间隔单位

可用的type参数值如下:
在这里插入图片描述
注意:type可以复合型的,比如 YEAR_MONTH。如果type不是复合型的,DATE_ADD和DATE_SUB其实可以通用,因为expr可以为一个负数。对应复合型的type,需要使用引号对两个参数进行引用起来,中间用任何非数字字符作为间隔即可,并且不能使用负数。但是时间间隔只指定了一个值, 那么也能正常工作,但是对应XXX_YYY使用的是下划线后YYY的单位,也就相当于 一单位的type,这时也就可以使用负数。

示例代码

复合型

select date_add('2024-04-29', interval '1 2' YEAR_MONTH); #结果:2025-06-29                                      
select date_add('2024-04-29', interval '1-2' YEAR_MONTH); #结果:2025-06-29                                    
select date_add('2024-04-29', interval '1,2' YEAR_MONTH); #结果:2025-06-29                                  
select date_add('2024-04-29', interval 1 YEAR_MONTH);  #结果:2024-05-29                              
select date_add('2024-04-29', interval -1 YEAR_MONTH); #结果:2024-03-29  # 这里先减1年,再减2月,最后减1天,有点意思
select date_sub('2024-04-29', interval '1 2' YEAR_MONTH); #结果:2023-02-28                                      
select date_sub('2024-04-29', interval '1-2' YEAR_MONTH); #结果:2023-02-28                                    
select date_sub('2024-04-29', interval '1,2' YEAR_MONTH); #结果:2023-02-28     select date_sub('2024-04-29', interval 1 YEAR_MONTH);  #结果:2024-03-29                              
select date_sub('2024-04-29', interval -1 YEAR_MONTH); #结果:2024-05-29                                                 

非复合型

select date_add(now(), interval 1 day); # 加1天 2024-04-30 16:25:49
select date_add(now(),INTERVAL -1 DAY); # 当前日期向前推1天 2024-04-28 16:25:49
select date_add(now(), interval 1 hour);# 加1小时 2024-04-29 17:25:49
select date_add(now(), interval 1 minute); # 加1分钟 2024-04-29 16:26:49
select date_add(now(), interval 1 second); # 加1秒 2024-04-29 16:25:50
select date_add(now(), interval 1 microsecond); # 加1毫秒 2024-04-29 16:25:49.000001
select date_add(now(), interval 1 week); # 加1周 2024-05-06 16:25:49
select date_add(now(), interval 1 month);# 加1月 2024-05-29 16:25:49
select date_add(now(), interval 1 quarter); # 加1季 2024-07-29 16:25:49
select date_add(now(), interval 1 year);# 加1年 2025-04-29 16:25:49select date_sub(now(), interval 1 day); # 减1天 2024-04-28 16:31:34
select date_sub(now(),INTERVAL -1 DAY); # 当前日期向后推1天 2024-04-30 16:31:34
select date_sub(now(), interval 1 hour);# 减1小时 2024-04-29 15:31:34
select date_sub(now(), interval 1 minute); # 减1分钟 2024-04-29 16:30:34
select date_sub(now(), interval 1 second); # 减1秒 2024-04-29 16:31:33
select date_sub(now(), interval 1 microsecond); # 减1毫秒 2024-04-29 16:31:33.999999
select date_sub(now(), interval 1 week); # 减1周 2024-04-22 16:31:34
select date_sub(now(), interval 1 month);# 减1月 2024-03-29 16:31:34
select date_sub(now(), interval 1 quarter); # 加1季 2024-01-29 16:31:34
select date_sub(now(), interval 1 year);# 减1年 2023-04-29 16:31:34 

运用

电商系统往往会有这样一个功能,客户收到货后如果七天不点击收货按钮话,系统会自动将订单设置为完成。这个功能就要求查询妥投七天后没有点击收货按钮的订单,将它们设置为完成。

相关SQL:

SELECTo.order_id,o.third_order_idFROMcere_shop_order oWHEREo.state < 4AND o.interface_call_time <= DATE_SUB(NOW(), INTERVAL 7 DAY)

state 订单状态,小于4查询未完成的订单,interface_call_time为妥投时间,o.interface_call_time <= DATE_SUB(NOW(), INTERVAL 7 DAY) 这里将当前时间减去7天后,再去和妥投时间进行比较,小于或等于这个结果的都是妥投超过了7天的订单。
这是比较推荐的写法,但还可以写成

SELECTo.order_id,o.third_order_idFROMcere_shop_order oWHEREo.state < 4AND DATE_ADD(o.interface_call_time,INTERVAL 7 DAY) < NOW();

这种写法将要查询的字段参与了函数计算,索引会失效,将会值全表扫描,性能很差,不推荐送使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/5131.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java基础郎波版chapter4习题

文章目录 1.试说明Java语言是如何支持多重继承的。2.类的构造方法和成员方法之间有什么区别?构造方法&#xff1a;成员方法&#xff1a; 3.编写程序片段,定义表示课程的类Course。4.编写程序创建习题3中的Course类的对象,设置并打印输出该对象的课程名、编号以及先修课号。5.J…

Python数组类+AI插件

目录 规划实现初始化插入删除查找 AI插件单测注释调优建议 小结 规划 先想清楚都写哪些&#xff0c;然后再动手操作 用Python写了一个简单数组类&#xff0c;首先思考下都写哪些功能&#xff1a; 插入删除查找用插件做单元测试和写注释 目的只是实现一个简单的数组类&#x…

Python自学篇3-PyCharm开发工具下载、安装及应用

一、Python开发工具 自学篇1中讲到了安装Python之后出现的几个应用程序&#xff0c;其中IDLE、Python.exe都可以用来编写python程序&#xff0c;也可以进行调试&#xff1b;但是比较基础&#xff0c;比较原始&#xff0c;调试不方便&#xff0c;界面也不友好&#xff0c;需要更…

(06)vite与ts的结合

文章目录 系列全集package.json在根目录创建 tsconfig.json 文件在根目录创建 vite.config.ts 文件index.html额外的类型声明 系列全集 &#xff08;01&#xff09;vite 从启动服务器开始 &#xff08;02&#xff09;vite环境变量配置 &#xff08;03&#xff09;vite 处理 c…

【报错】Could not autowire. No beans of ‘SysUserRoleService‘ type found

1.查看对应service层是否添加Service 2.可以修改成Resource注入&#xff0c; Autowired和Resource区别一个是默认按照类型&#xff0c;一个默认按照名字 3.解决办法是&#xff1a;降低Autowired检测的级别&#xff0c;将Severity的级别由之前的error改成warning或其它可以忽略…

【C++干货基地】探索C++模板的魅力:如何构建高性能、灵活且通用的代码库(文末送书)

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 引入 哈喽各位铁汁们好啊&#xff0c;我是博主鸽芷咕《C干货基地》是由我的襄阳家乡零食基地有感而发&#xff0c;不知道各位的…

http1.1和http2.0的同源请求数限制

判断协议版本 :scheme: 在请求头中表示使用的是HTTP/2协议。即 出现 :开头的请求头Chrome 只支持查看 HTTP/1.x 的 Raw Headers&#xff0c;对这种请求&#xff0c;会给出 view source 选项。HTTP2.0不给出。可继续学习 https://www.cnblogs.com/kirito-c/p/10360868.html抓包…

用什么模型算法可以预测足球胜平负

预测足球胜平负的模型算法有很多种&#xff0c;每种算法都有其特点和适用场景。以下是一些常见的模型算法&#xff1a; Elo预测法&#xff1a; 这是一种通过研究主客场球队在比赛前的积分情况来预测胜负的方法。Elo预测法通过计算两队之间的积分差&#xff0c;根据特定的公式&…

uTorrent Pro一款轻量级的Torrent磁力下载工具去广告绿色版 v3.6.0.47044

01 uTorrent Pro v3.6.0.47044 Torrent是一款俄罗斯号称全球排名第一的免费BT下载工具,海外最受欢迎的BT下载客户端软件。支持UPnP&#xff0c;支持流行的 BT 扩展协议&#xff0c;磁力链接(Magnet Links)&#xff0c;IPv6&#xff0c;用户来源交换&#xff0c;DHT和uTP&#…

计算机科学与技术就业方向和前景怎么样

计算机科学与技术专业的就业方向极为广泛&#xff0c;方向可以是软件开发与工程、网络与信息安全、数据科学与大数据分析等&#xff0c;几乎渗透到现代社会的每一个角落。以下是上大学网 &#xff08;www.sdaxue.com)对计算机科学与技术专业一些主要的就业方向及其前景分析&…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-8.1--C语言LED驱动程序

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

流水线工作流程

java编译命令&#xff1a; java -jar xxx.jar (其它参数已忽略) docker镜像构建命令&#xff1a; docker build -t [镜像名称:latest] -f 指定[Dockerfile] [指定工作目录] 推送镜像 jenkinsfile: 主要流程登录镜像仓库&#xff0c;打包镜像&#xff0c;推送到镜像仓库

情感类ppt素材

小清新手绘插画风毕业季毕业相册同学录画册纪念册PPT下载 - 觅知网这是一张关于清新毕业相册的PPT模板&#xff0c;清新风格设计&#xff0c;加上风为装饰元素&#xff0c;包含毕业相册、毕业季、毕业、同学、纪念等主题内容&#xff0c;也可用作毕业相册PPT、毕业季PPT、毕业P…

Springboot+Vue项目-基于Java+MySQL的校园疫情防控系统(附源码+演示视频+LW)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &…

蓝桥杯如何准备国赛?

目录 一、赛前准备 1、如何刷题&#xff0c;刷哪些题&#xff1f; 2、记录&#xff08;主要看个人习惯&#xff09; CSDN博客 写注释 3、暴力骗分 4、从出题人的角度出发&#xff0c;应该如何骗分 二、赛中注意事项 一、赛前准备 1、如何刷题&#xff0c;刷哪些题&…

(51单片机)第十三章-STC系列51单片机功能介绍

13.1 单片机空闲与掉电模式的应用 1. 空闲模式 当单片机进入空闲模式时&#xff0c;除CPU处于休眠状态外&#xff0c;其余硬件全部处于活动状态&#xff0c;芯片中程序未涉及的数据存储器和特殊功能寄存器中的数据在空闲模式期间都将保持原值。假若定时器正在运行&#xff0c;…

第十二章 案例二:配置Trunk,实现相同VLAN的跨交换机通信

1、实验环境 公司的员工人数已达到 100 人&#xff0c;其网络设备如图12.13所示&#xff0c;现在的网络环境导致广播较多网速慢&#xff0c;并且也不安全&#xff0c;公司希望按照部门划分网络&#xff0c;并且能够保证一定的网络安全性 图12.13 实验案例二拓扑图 其网络规划…

KKView远程控制2.0版本发布,TeamViewer面临巨大挑战

KKView远程控制2.0版本发布&#xff0c;TeamViewer面临巨大挑战 近日&#xff0c;备受瞩目的远程控制软件KKView发布了其全新2.0版本&#xff0c;KKView以其独特的创新性和用户友好的设计&#xff0c;为远程办公、远程培训等领域提供了更加高效、便捷的解决方案。 KKView远程…

ubuntu samba 安装与配置

ubuntu samba 安装与配置 一&#xff1a;安装二&#xff1a;添加samba访问账号及密码三&#xff1a;修改配置文件四&#xff1a;重启服务五&#xff1a;登录 一&#xff1a;安装 sudo apt update sudo apt install samba samba-common二&#xff1a;添加samba访问账号及密码 …

【MATLAB】解决不同版本MATLAB出现中文乱码的问题

解决不同版本MATLAB出现中文乱码的问题 方法1&#xff1a;更改保存类型为GBK方法2&#xff1a;记事本打开方法3&#xff1a;Notepad参考 低版本matlab打开高版本Matlab的.m文件时&#xff0c;出现中文乱码问题。比如下图&#xff1a; 出现原因为&#xff1a; 编码格式不统一问…