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

Oracle中ADD_MONTHS()函数详解

文章目录

  • 前言
  • 一、ADD_MONTHS()的语法
  • 二、主要用途
  • 三、测试用例
  • 总结


前言

在Oracle数据库中,ADD_MONTHS()函数用于在日期中添加指定的月数。


一、ADD_MONTHS()的语法

ADD_MONTHS(date, n)

其中,date是一个日期值,n是一个整数值,表示要添加的月数。

此函数将返回一个新的日期,该日期是在给定日期的基础上添加指定月数后得到的。

注意,如果n为正数,则添加的是未来的月数;如果n为负数,则添加的是过去的月数。

二、主要用途

Oracle中的ADD_MONTHS()函数主要用于在给定的日期上添加指定的月份。它接受两个参数,第一个参数是一个日期值,可以是日期数据类型或带有日期值的字符串,第二个参数是要添加的月份数。函数返回一个新的日期,该日期是在给定日期的基础上添加了指定的月份数。

ADD_MONTHS()函数还可以处理闰年和月底的情况。如果给定的日期是闰年的2月29日,并且要添加的月份数导致结果日期是一个非闰年的2月29日,函数会将结果日期调整为2月28日。

此外,如果给定的日期是一个月的最后一天,并且要添加的月份数导致结果日期中没有该月,则函数将返回结果日期中的上个月的最后一天。

三、测试用例

测试SQL:

SELECT 
ADD_MONTHS(TO_DATE('2024-10-01', 'YYYY-MM-DD'), 1)    AS DATE1,
ADD_MONTHS(TO_DATE('2024-10-01', 'YYYY-MM-DD'), -1)   AS DATE2,
ADD_MONTHS(TO_DATE('2024-10-01', 'YYYY-MM-DD'), 1.9)  AS DATE3,
ADD_MONTHS(TO_DATE('2024-10-01', 'YYYY-MM-DD'), 1.1)  AS DATE4,
ADD_MONTHS(TO_DATE('2024-10-31', 'YYYY-MM-DD'), 1)    AS DATE5
FROM DUAL;

测试结果:
在这里插入图片描述

由以上测试用例,可以看出以下几点,尤其需要注意第三点这个特殊情况

1、n可以为正整数,也可以为负整数。

2、n为小数时,不会四舍五入,而会直接取整数部分,小数不分不参与运算。因此1.9和1.1的结果一致。

3、如果给定的日期是一个月的最后一天,并且要添加的月份数导致结果日期中没有该月,则函数将返回结果日期中的上个月的最后一天。比如:10月31日增加1一个月,应为11月31日,但11月没有31日,因此返回11月30日。


总结

总之,ADD_MONTHS()函数是在Oracle中用于处理日期计算和操作的一个非常有用的函数。

如果这篇博客对大家有所帮助,我希望能得到各位的免费点赞收藏,作为对我的鼓励和支持。
同时,也请大家在评论区留下您宝贵的意见和建议,我将非常欢迎。
感谢大家的支持评论收藏!!!

http://www.lryc.cn/news/455785.html

相关文章:

  • 【SQL】掌握SQL查询技巧:高效数据整合与查询优化
  • 一个月学会Java 第5天 控制结构
  • 世界职业院校技能大赛(大数据技术与应用)参赛项目介绍内容模拟示例参考
  • 【Python】文件及目录
  • OpenHarmony(鸿蒙南向开发)——标准系统方案之瑞芯微RK3566移植案例(下)
  • 霓虹灯数字时钟(可复制源代码)
  • 大模型微调技术之 LoRA:开启高效微调新时代
  • 【Vue】Vue2(2)
  • 如何实现一个基于 HTML+CSS+JS 的任务进度条
  • 学会流体力学,冬天洗澡再也不冷啦
  • WPF下使用FreeRedis操作RedisStream实现简单的消息队列
  • 踩坑NVTX
  • Ubuntu修改IP方法
  • C++——STL简介
  • [linux] 磁盘清理相关
  • 【笔记】DDD领域驱动设计
  • 用AI构建小程序需要多久?效果如何?
  • 深度学习的应用综述
  • whereis命令:查找命令的路径
  • 【ECMAScript 从入门到进阶教程】第四部分:项目实践(项目结构与管理,单元测试,最佳实践与开发规范,附录)
  • 算法讲解—最小生成树(Kruskal 算法)
  • 掌握 C# 多线程与异步编程
  • Angular 2 用户输入
  • 线程安全的单例模式 | 可重入 | 线程安全 |死锁(理论)
  • 解决方案:梯度提升树(Gradient Boosting Trees)跟GBDT(Gradient Boosting Decision Trees)有什么区别
  • 亚马逊国际商品详情API返回值:电商精准营销的关键
  • python爬虫 - 进阶requests模块
  • 代码随想录 103. 水流问题
  • 数据结构-排序1
  • Springboot 整合 durid