当前位置: 首页 > news >正文

mysql中的计算日期函数 理解、用法

三种计算日期的函数

函数用途示例
DATEDIFF()计算两个日期的天数差DATEDIFF('2023-10-05', '2023-10-01') → 4
TIMESTAMPDIFF()按指定单位(年、月、小时等)计算差TIMESTAMPDIFF(MONTH, '2023-01-01', '2023-03-01') → 2
DATE_ADD()日期加法DATE_ADD('2023-10-01', INTERVAL 7 DAY) → '2023-10-08'

 常用的是:DATEDIFF()基本语法

sql

DATEDIFF(end_date, start_date)
  • 参数
    • end_date:结束日期(将被减数)。
    • start_date:开始日期(减数)。
  • 返回值end_date - start_date 的天数差(整数)。
    • 若 end_date 早于 start_date,返回负数。

示例场景

示例 1:基本计算

sql

SELECT DATEDIFF('2023-10-05', '2023-10-01') AS diff_1,  -- 输出:4DATEDIFF('2023-10-01', '2023-10-05') AS diff_2;  -- 输出:-4
示例 2:结合表字段

sql

-- 计算订单下单日期与发货日期的间隔
SELECT order_id,DATEDIFF(shipped_date, order_date) AS days_to_ship
FROM orders;
示例 3:动态日期

sql

-- 计算距离今天还有多少天
SELECT DATEDIFF('2023-12-31', CURDATE()) AS days_remaining;

 

常见问题与注意事项

1. 参数顺序陷阱
  • 确保第一个参数是更晚的日期,否则结果可能为负数:

    sql

    -- 错误写法(可能返回负数)
    SELECT DATEDIFF(start_date, end_date);
    -- 正确写法
    SELECT DATEDIFF(end_date, start_date);
    
2. 时间部分被忽略
  • 若需精确到小时/分钟,改用 TIMESTAMPDIFF()

    sql

    SELECT TIMESTAMPDIFF(HOUR, '2023-10-01 08:00:00', '2023-10-01 20:30:00');
    -- 输出:12(小时差)
    
3. 时区无关性
  • 计算基于输入的日期值,不自动转换时区。若需处理时区,先显式转换:

    sql

    SELECT DATEDIFF(CONVERT_TZ('2023-10-01', '+00:00', '+08:00'), '2023-09-30');
  • 核心用途:快速计算两个日期的间隔天数。
  • 适用场景:统计业务周期、计算有效期剩余天数、分析事件间隔等。
  • 避坑指南:注意参数顺序、忽略时间的特性,避免无效日期输入。

 

相关文章:

mysql中的计算日期函数 理解、用法

三种计算日期的函数 函数用途示例DATEDIFF()计算两个日期的天数差DATEDIFF(2023-10-05, 2023-10-01) → 4TIMESTAMPDIFF()按指定单位(年、月、小时等)计算差TIMESTAMPDIFF(MONTH, 2023-01-01, 2023-03-01) → 2DATE_ADD()日期加法DATE_ADD(2023-10-01, …...

从零开始用react + tailwindcs + express + mongodb实现一个聊天程序(一)

项目包含5个模块 1.首页 (聊天主页) 2.注册 3.登录 4.个人资料 5.设置主题 一、配置开发环境 建立项目文件夹 mkdir chat-project cd chat-project mkdir server && mkdir webcd server npm init cd web npm create vitelatest 创建前端项目时我们选择javascrip…...

wifi5和wifi6,WiFi 2.4G、5G,五类网线和六类网线,4G和5G的区别

wifi5和wifi6的区别 是Wi-Fi 5和Wi-Fi 6的选择与路由器密切相关。路由器是创建和管理无线网络的设备,它决定了网络的类型和性能。具体来说: 路由器的标准支持:路由器可以支持不同的Wi-Fi标准,如Wi-Fi 5(802.11ac)和Wi-Fi 6(802.11ax)。支持Wi-Fi 6的路由器能够提供更高…...

Docker基础-常见命令

docker images -查看所有的本地镜像。 docker pull -把远端镜像拉取到本地。 docker rmi -删除镜像。 docker push -推到镜像仓库。 docker run -创建并运行容器(自动化,如果发现镜像不存在会先去拉取, 拉取完了以后再去自动创建容器&am…...

从零开始用react + tailwindcs + express + mongodb实现一个聊天程序(三) 实现注册 登录接口

1.划分文件夹 在src目录下创建controllers middleware models routes controllers 放具体的方法 signup login middleware 里面是中间件 请求的验证 models 放对象实体 routes 处理访问路径像/signup /login 等等 2. 接口开发 系统的主要 有用户认证 和 消息 2种类型…...

Android NFC功能开发指南

在 Android 平台上开发 NFC&#xff08;近场通信&#xff09;功能&#xff0c;主要涉及以下几个步骤&#xff1a; 1. 权限声明 首先&#xff0c;在 AndroidManifest.xml 文件中声明 NFC 权限&#xff1a; <uses-permission android:name"android.permission.NFC&quo…...

基于Matlab实现汽车远近光灯识别的详细步骤及代码示例

以下是一个基于Matlab实现汽车远近光灯识别的详细步骤及代码示例&#xff0c;主要通过图像处理技术来区分远光灯和近光灯。 整体思路 图像预处理&#xff1a;包括读取图像、灰度化、去噪等操作&#xff0c;以提高后续处理的准确性。边缘检测&#xff1a;找出图像中的边缘信息…...

nginx反向代理以及负载均衡(常见案例)

一、nginx反向代理 1、什么是代理服务器&#xff1f; 代理服务器&#xff0c;客户机在发送请求时&#xff0c;不会直接发送给目的主机&#xff0c;而是先发送给代理服务器&#xff0c;代理服务接受客户机请求之后&#xff0c;再向主机发出&#xff0c;并接收目的主机返回的数据…...

Spring 三级缓存机制(解决循环依赖)

文章目录 &#x1f504; 现实生活类比&#xff1a;开餐厅的过程&#x1f4a1; 结合到 Spring 三级缓存&#x1f6e0;️ Spring 解决循环依赖的步骤1️⃣ Spring 开始创建 A2️⃣ Spring 开始创建 B3️⃣ B 创建完成后&#xff0c;回过头来继续创建 A &#x1f4cc; 三级缓存的作…...

第4章 4.4 EF Core数据库迁移 Add-Migration UpDate-Database

4.4.1 数据库迁移原理 总结一下就是&#xff1a; 1. 数据库迁移命令的执行&#xff0c;其实就是生成在数据库执行的脚本代码&#xff08;两个文件&#xff1a;数字_迁移名.cs 数字_迁移名.Designer.cs&#xff09;&#xff0c;用于对数据库进行定义和修饰。 2. 数据库迁移…...

web安全——web应用程序技术

文章目录 一、HTTP1.1 HTTP方法1.2 HTTP消息头1.3 cookie1.4 状态码 二、web功能2.1 服务器端功能2.2 客户端功能——同源策略 三、编码方案3.1 URL编码3.2 Unicode编码3.3 HTML编码3.4 Base64编码 一、HTTP HTTP&#xff08;超文本传输协议&#xff09;是web应用程序使用的通…...

low rank decomposition如何用于矩阵的分解

1. 什么是矩阵分解和低秩分解 矩阵分解是将一个矩阵表示为若干结构更简单或具有特定性质的矩阵的组合或乘积的过程。低秩分解&#xff08;Low Rank Decomposition&#xff09;是其中一种方法&#xff0c;旨在将原矩阵近似为两个或多个秩较低的矩阵的乘积&#xff0c;从而降低复…...

GO 进行编译时插桩,实现零码注入

Go 编译时插桩 Go 语言的编译时插桩是一种在编译阶段自动注入监控代码的技术&#xff0c;目的是在不修改业务代码的情况下&#xff0c;实现对应用程序的监控和追踪。 基本原理 Go 编译时插桩的核心思想是通过在编译过程中对源代码进行分析和修改&#xff0c;将监控代码注入到…...

编写一个程序,输入一个字符串并输出其长度(Java版)

编写一个程序&#xff0c;输入一个字符串并输出其长度 以下是Java实现代码&#xff1a; import java.util.Scanner;public class StringLengthCalculator {public static void main(String[] args) {Scanner scanner new Scanner(System.in);System.out.print("请输入一…...

C++ day4 练习

一、练习1 找到第一天mystring练习&#xff0c;实现以下功能&#xff1a; mystring str "hello"; mystring ptr "world"; str str ptr; str ptr; str[0] H; 【代码】&#xff1a; #include <iostream> #include <cstring> #include &l…...

深入理解指针2

深入理解指针2 数组名的理解 数组名就是首元素的地址 int arr[]{1,3,2}; printf("%p\n",arr); printf("%p\n",&arr[0]);但是有两种情况除外&#xff0c; 1.sizeof(数组名)&#xff0c;sizeof操作符统计的是整个数组的大小&#xff0c;并不是第一个元素…...

【STL专题】优先级队列priority_queue的使用和模拟实现,巧妙利用仿函数解决优先级

欢迎来到 CILMY23的博客 &#x1f3c6;本篇主题为&#xff1a;优先级队列priority_queue的使用和模拟实现&#xff0c;巧妙利用仿函数解决优先级 &#x1f3c6;个人主页&#xff1a;CILMY23-CSDN博客 &#x1f3c6;系列专栏&#xff1a; C | C语言 | 数据结构与算法 | Linux…...

CPU、SOC、MPU、MCU--详细分析四者的区别

一、CPU 与SOC的区别 1.CPU 对于电脑&#xff0c;我们经常提到&#xff0c;处理器&#xff0c;内存&#xff0c;显卡&#xff0c;硬盘四大部分可以组成一个基本的电脑。其中的处理器——Central Processing Unit&#xff08;中央处理器&#xff09;。CPU是一台计算机的运算核…...

Node.js 内置模块简介(带示例)

目录 1. fs&#xff08;文件系统&#xff09;模块 2. http 模块 3. path 模块 4. os 模块 5. events 模块 6. crypto 模块 1. fs&#xff08;文件系统&#xff09;模块 fs 模块提供了与文件系统进行交互的功能&#xff0c;包括文件的读写、删除、重命名等操作。它有同步…...

常见的“锁”有哪些?

悲观锁 悲观锁认为在并发环境中&#xff0c;数据随时可能被其他线程修改&#xff0c;因此在访问数据之前会先加锁&#xff0c;以防止其他线程对数据进行修改。常见的悲观锁实现有&#xff1a; 1.互斥锁 原理&#xff1a;互斥锁是一种最基本的锁类型&#xff0c;同一时间只允…...

3步实现PCB可视化BOM管理:InteractiveHtmlBom实战指南

3步实现PCB可视化BOM管理&#xff1a;InteractiveHtmlBom实战指南 【免费下载链接】InteractiveHtmlBom Interactive HTML BOM generation plugin for KiCad, EasyEDA, Eagle, Fusion360 and Allegro PCB designer 项目地址: https://gitcode.com/gh_mirrors/in/InteractiveH…...

馈线自动化(FA)如何重塑现代配电网?核心价值与技术路径解析

1. 馈线自动化&#xff1a;配电网的"智能医生" 想象一下凌晨三点你家突然停电的场景。传统配电网下&#xff0c;抢修人员需要逐段排查故障点&#xff0c;可能几小时后才能恢复供电。而配备了馈线自动化&#xff08;FA&#xff09;的智能配电网&#xff0c;能在90秒内…...

解锁数字记忆:WeChatExporter如何成为你的微信时光胶囊

解锁数字记忆&#xff1a;WeChatExporter如何成为你的微信时光胶囊 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 在数字时代的洪流中&#xff0c;我们的记忆正悄然从大…...

免费终极视频修复工具:5分钟拯救你的损坏MP4文件

免费终极视频修复工具&#xff1a;5分钟拯救你的损坏MP4文件 【免费下载链接】untrunc Restore a damaged (truncated) mp4, m4v, mov, 3gp video. Provided you have a similar not broken video. 项目地址: https://gitcode.com/gh_mirrors/unt/untrunc 你是否曾因视频…...

2026最新鸿蒙开发面试题合集(含详细解析,适配ArkTS V2/HarmonyOS NEXT)

说明&#xff1a;本合集聚焦2026年鸿蒙开发核心考点&#xff0c;结合HarmonyOS NEXT&#xff08;API 10&#xff09;、ArkTS V2最新特性&#xff0c;覆盖基础入门、进阶核心、实战场景、架构设计四大模块&#xff0c;每题均附详细解析&#xff08;标注高频考点&#xff09;&…...

Qwen3-Reranker-4B部署教程:适配A10/A100/V100的GPU算力优化配置

Qwen3-Reranker-4B部署教程&#xff1a;适配A10/A100/V100的GPU算力优化配置 本文手把手教你如何在A10/A100/V100等主流GPU上部署Qwen3-Reranker-4B模型&#xff0c;从环境准备到服务调用&#xff0c;提供完整的优化配置方案。 1. 认识Qwen3-Reranker-4B模型 Qwen3-Reranker-4…...

OpenSimpleLidar开源激光雷达:低成本DIY扫描测距仪完全指南

OpenSimpleLidar开源激光雷达&#xff1a;低成本DIY扫描测距仪完全指南 【免费下载链接】OpenSimpleLidar Open Source scanning laser rangefinder 项目地址: https://gitcode.com/gh_mirrors/op/OpenSimpleLidar OpenSimpleLidar是一款开源激光雷达项目&#xff0c;专…...

技术决策中的信息收集与分析判断

技术决策中的信息收集与分析判断&#xff1a;构建智能决策的核心支柱 在数字化时代&#xff0c;技术决策的质量直接影响企业的竞争力和发展潜力。无论是选择技术架构、开发工具&#xff0c;还是评估新兴技术的可行性&#xff0c;信息收集与分析判断都是决策过程中的关键环节。…...

IntelliPro 企业级产研协作平台:前端智能生产模块设计与落地

摘要 当前企业级前端研发面临复杂度高、迭代快、跨团队协作成本高的痛点&#xff0c;传统开发模式难以适配高效产研需求。本文围绕 IntelliPro 平台前端智能生产模块&#xff0c;拆解其定位、分层架构、智能代理体系与落地保障&#xff0c;输出企业前端智能化研发的实践方案。 …...

大模型到底是啥?运维人分钟搞懂(不用数学)匙

1. 流图&#xff1a;数据的河流 如果把传统的堆叠面积图想象成一块块整齐堆叠的积木&#xff0c;那么流图就像一条蜿蜒流淌的河流&#xff0c;河道的宽窄变化自然流畅&#xff0c;波峰波谷过渡平滑。 它特别适合展示多个类别数据随时间的变化趋势&#xff0c;尤其是当你想强调整…...