Mysql SQL 超实用的7个日期算术运算实例(10k)

文章目录

  • 前言
      • 1. 加上或减去若干天、若干月或若干年
        • 基本语法
        • 使用场景
        • 注意事项
        • 运用实例
        • 分析说明
      • 2. 确定两个日期相差多少天
        • 基本语法
        • 使用场景
        • 注意事项
        • 运用实例
        • 分析说明
      • 3. 确定两个日期之间有多少个工作日
        • 基本语法
        • 使用场景
        • 注意事项
        • 运用实例
        • 分析说明
      • 4. 确定两个日期相隔多少个月或多少年
        • 基本语法
        • 使用场景
        • 注意事项
        • 运用实例
        • 分析说明
      • 5. 确定两个日期相隔多少秒、多少分钟或多少小时
        • 基本语法
        • 使用场景
        • 注意事项
        • 运用实例
        • 分析说明
      • 6. 确定两个日期相隔多少秒、多少分钟或多少小时
        • 基本语法
        • 使用场景
        • 注意事项
        • 运用实例
        • 分析说明
      • 7. 确定当前记录和下一条记录存储的日期相隔多少天
        • 基本语法
        • 使用场景
        • 注意事项
        • 运用实例
        • 分析说明
  • 总结


前言

在MySQL中,可以使用各种函数来执行日期和时间的算术运算。以下是常用的日期算术运算函数:

  1. DATE_ADD() 和 DATE_SUB():在日期上加上或减去指定的时间间隔。
  2. TIMESTAMPDIFF():计算两个日期之间的差异,以指定的时间单位返回。
  3. DATEDIFF():计算两个日期之间的天数差异。
  4. DAYOFWEEK():确定一个日期是星期几,用于计算工作日。
  5. UNIX_TIMESTAMP():将日期转换为Unix时间戳,用于计算秒数差异。

1. 加上或减去若干天、若干月或若干年

基本语法

在MySQL中,可以使用DATE_ADD()DATE_SUB()函数来对日期进行算术运算。

  • 加上若干天、月或年

    DATE_ADD(date, INTERVAL value unit);
    
    • date:原始日期。
    • value:要加上的天数、月数或年数。
    • unit:时间单位,可以是DAYMONTHYEAR
  • 减去若干天、月或年

    DATE_SUB(date, INTERVAL value unit);
    
    • date:原始日期。
    • value:要减去的天数、月数或年数。
    • unit:时间单位,可以是DAYMONTHYEAR
使用场景
  • 日期调整:计算未来的日期或过去的日期,如计算项目的开始日期或结束日期。
  • 年龄计算:根据出生日期计算年龄。
  • 到期日计算:计算账单或订阅的到期日。
注意事项
  • 闰年:在加上或减去年时,需要注意闰年的影响,特别是当涉及到2月份时。
  • 月份天数:在加上或减去月时,如果目标月没有足够的天数,日期会调整到该月的最后一天。例如,从1月31日减去1个月会得到2月28日或29日。
  • 负值:可以指定负值来减去天数、月数或年数。
运用实例
  • 加上10天

    SELECT DATE_ADD('2023-01-01', INTERVAL 10 DAY);
    
    • 结果:2023-01-11
  • 减去2个月

    SELECT DATE_SUB('2023-03-15', INTERVAL 2 MONTH);
    
    • 结果:2023-01-15
  • 加上1年

    SELECT DATE_ADD('2023-01-01', INTERVAL 1 YEAR);
    
    • 结果:2024-01-01
分析说明
  • DATE_ADD()DATE_SUB() 是非常强大的函数,它们允许你轻松地对日期进行加减运算。
  • 当涉及到月份和年份的加减时,这些函数会自动处理不同月份的天数和闰年,使得日期计算变得简单。
  • 在进行日期计算时,了解这些函数如何处理月份和年份的边界情况是非常重要的,这可以帮助你避免计算错误。
  • 这些函数在处理业务逻辑,如日期有效性检查、年龄计算、日期范围查询等方面非常有用。

通过使用这些函数,你可以在MySQL中轻松地进行日期算术运算,以支持各种需要日期计算的业务需求。

2. 确定两个日期相差多少天

基本语法

在MySQL中,可以使用DATEDIFF()函数来确定两个日期之间相差的天数。

DATEDIFF(date1, date2);
  • date1:较晚的日期。
  • date2:较早的日期。
使用场景
  • 时间间隔计算:计算两个事件之间的时间间隔,如项目持续时间、年龄或两个订单之间的时间差。
  • 历史数据分析:分析特定时间段内的数据变化,如用户活跃度或销售趋势。
  • 日程规划:确定事件或预约之间的间隔,如会议或假期的安排。
注意事项
  • 日期顺序DATEDIFF()函数要求第一个参数是较晚的日期,第二个参数是较早的日期。如果顺序颠倒,结果将是负数。
  • 时区影响:确保两个日期都在同一时区,否则可能会影响计算结果。
  • 日期格式:确保两个日期的格式正确,且能够被MySQL正确解析。
运用实例

假设我们想要计算从2023-01-012023-01-15之间相差的天数:

SELECT DATEDIFF('2023-01-15', '2023-01-01') AS days_difference;
  • 结果:14
分析说明
  • 直观结果DATEDIFF()函数提供了一个直观的方式来获取两个日期之间的天数差异。
  • 负值处理:如果你需要避免负值,可以使用ABS()函数来获取绝对值:ABS(DATEDIFF(date1, date2))
  • 性能DATEDIFF()是一个轻量级的函数,通常对性能影响很小,适合在大型查询中使用。
  • 业务逻辑:在业务逻辑中,这个函数可以用来计算用户注册后的活动天数、产品的生命周期、或者任何需要基于时间间隔的计算。

通过使用DATEDIFF()函数,你可以轻松地在MySQL中计算两个日期之间的天数差异,这对于许多需要日期间隔分析的场景非常有用。

3. 确定两个日期之间有多少个工作日

基本语法

在MySQL中,确定两个日期之间有多少个工作日通常需要自定义查询或存储过程,因为MySQL没有内置的函数直接计算工作日。以下是一种基本的方法:

SELECTSUM(CASEWHEN WEEKDAY(date) BETWEEN 1 AND 5 THEN 1ELSE 0END) AS workdays
FROM(SELECT DATE_ADD('起始日期', INTERVAL a.day - 1 

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

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

相关文章

VSCode设置ctrl或alt+mouse(left)跳转

总结: (1)VSCode初次远程连接服务器时,需要在服务器上下载 python 拓展,然后选择对应的环境 (2)VSCode设置ctrl或altmouse(left)跳转到定义

VBA 64位API声明语句第005讲

跟我学VBA,我这里专注VBA, 授人以渔。我98年开始,从源码接触VBA已经20余年了,随着年龄的增长,越来越觉得有必要把这项技能传递给需要这项技术的职场人员。希望职场和数据打交道的朋友,都来学习VBA,利用VBA,起码可以提高…

可扩展性设计架构模式——事件驱动架构

事件驱动架构(Event-Driven Architecture, EDA)是一种可扩展性设计软件架构模式,它通过事件来触发和通信(以事件为核心),实现不同系统组件之间的解耦(促进应用程序或系统部件之间的松耦合通信&a…

covid-vaccine-availability-using-flask-server

使用烧瓶服务器获得 Covid 疫苗 原文:https://www . geesforgeks . org/co vid-疫苗-可用性-使用-烧瓶-服务器/ 在本文中,我们将使用 Flask Server 构建 Covid 疫苗可用性检查器。 我们都知道,整个世界都在遭受疫情病毒的折磨,唯一能帮助我们…

设计模式从入门到精通之(三)单例模式

单例模式:只留一份独特的存在 在现代软件设计中,有些对象是必须确保"独一无二"的,比如程序中的配置管理器、线程池、数据库连接等。如果允许这些对象被反复创建,不仅会浪费系统资源,还可能导致程序逻辑出错。…

WordPress Crypto 插件 身份认证绕过漏洞复现(CVE-2024-9989)

0x01 产品简介 WordPress Crypto插件是指那些能够为WordPress网站提供加密货币支付、信息显示或交易功能的插件。这些插件通常与WordPress电子商务插件(如WooCommerce)集成,使网站能够接受多种加密货币支付,或展示加密货币实时信息。支持多种加密货币支付,付款直接进入钱…

hashMap追问

HashMap 7/8区别 不同点: (1)JDK1.7用的是头插法,而JDK1.8及之后使用的都是尾插法,那么他们为什么要这样做呢?因为JDK1.7是用单链表进行的纵向延伸,当采用头插法时会容易出现逆序且环形链表死…

网络安全:路由技术

概述 路由技术到底研究什么内容 研究路由器寻找最佳路径的过程 路由器根据最佳路径转发数据包 知识点,重要OSRF,BGP1.静态路由原理 路由技术分类 静态路由和动态路由技术 静态路由:是第一代路由技术,由网络管理员手工静态写路由/路径告知路…

IIS设置IP+端口号外网无法访问的解决方案

在IIS将站点设置为IP端口访问,假设端口为8080,设好后,服务器上可以访问,外网无法访问。 通常是端口8080没有加入【入站规则】的缘故,将8080端口加入【入站规则】即可,操作如下: 一、ctrlr 输入 …

使用 apply 方法将其他列的值传入 DataFrame 或 Series 的函数,来进行更灵活的计算或操作

可以使用 apply 方法将其他列的值传入 DataFrame 或 Series 的函数,来进行更灵活的计算或操作。apply 方法允许你逐行或逐列地对 DataFrame 或 Series 的元素进行操作,而且你可以将其他列的值作为参数传递给函数。 示例:使用 apply 结合其他…

计算机毕业设计Django+Tensorflow音乐推荐系统 音乐可视化 卷积神经网络CNN LSTM音乐情感分析 机器学习 深度学习 Flask

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

高速网络数据包处理中的内核旁路技术

该PPT详细介绍了Linux网络栈中数据包的传输路径、内核旁路技术的必要性以及具体的内核旁路技术,包括用户空间数据包处理和用户空间网络栈。主要内容概述: 数据包在Linux网络栈中的旅程:描述了数据包从发送到接收的完整路径,包括各…

el-form+el-date-picker组合使用时候的回显问题

背景 我有弹窗创建任务时间的需求,同时也可以修改任务时间,所以复用了弹窗和表单,但在表单里使用日期时间组件的时候,发现了问题 问题描述:在表单中使用form的属性绑定日期时间选择器的v-model,会出现的两…

分布式光伏规模界点为什么是6MW?

多省能源局规定大于6MW的电站必须按集中式管理,另外大于6MW(包含)要省级审批,小于则由市级审批,10kV线路单回接入容量也是6MW,很多电厂发电机装机容量也是以6MW为界点。这是什么原因呢? 配电网…

[2474].第04节:Activiti官方画流程图方式

我的后端学习大纲 Activiti大纲 1.安装位置: 2.启动:

Qt从入门到入土(七)-实现炫酷的登录注册界面(下)

前言 Qt从入门到入土(六)-实现炫酷的登录注册界面(上)主要讲了如何使用QSS样式表进行登录注册的界面设计,本篇文章将介绍如何对登录注册界面进行整体控件的布局,界面的切换以及实现登录、记住密码等功能。…

在 macOS 上,你可以使用系统自带的 终端(Terminal) 工具,通过 SSH 协议远程连接服务器

文章目录 1. 打开终端2. 使用 SSH 命令连接服务器3. 输入密码4. 连接成功5. 使用密钥登录(可选)6. 退出 SSH 连接7. 其他常用 SSH 选项8. 常见问题排查问题 1:连接超时问题 2:权限被拒绝(Permission denied&#xff09…

关于大一上的总结

大一上总结 前言 源于学长们都喜欢写总结,今晚也正好听见一首有点触动心灵的歌,深有感慨,故来此写下这篇总结 正文 1.暑假前的准备 暑假之前姑且还是学习了基本的C语法,大概是到了结构体的地方,进度很慢&#xff0…

Spring Cloud Gateway-自定义异常处理

参考 https://blog.csdn.net/suyuaidan/article/details/132663141,写法不同于注入方式不一样 ErrorWebFluxAutoConfiguration Configuration(proxyBeanMethods false) ConditionalOnWebApplication(type ConditionalOnWebApplication.Type.REACTIVE) Condition…

121.【C语言】数据结构之快速排序(未优化的Hoare排序存在的问题)以及时间复杂度的分析

目录 1.未优化的Hoare排序存在的问题 测试代码 "量身定制"的测试代码1 运行结果 "量身定制"的测试代码2 运行结果 "量身定制"的测试代码3 运行结果 分析代码1、2和3栈溢出的原因 排有序数组的分析 分析测试代码1:给一个升序数组,要求排…