首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用oracle SQL获取过去两年中每个月的最后一天。

使用Oracle SQL获取过去两年中每个月的最后一天,可以使用以下查询语句:

代码语言:txt
复制
SELECT TO_CHAR(LAST_DAY(ADD_MONTHS(SYSDATE, -24) + LEVEL - 1), 'YYYY-MM-DD') AS Last_Day
FROM DUAL
CONNECT BY LEVEL <= ADD_MONTHS(SYSDATE, -12) - ADD_MONTHS(SYSDATE, -24) + 1;

这个查询语句使用了Oracle SQL的内置函数LAST_DAYADD_MONTHSLAST_DAY函数用于获取指定日期所在月份的最后一天,ADD_MONTHS函数用于在指定日期上增加或减少指定的月份数。

解释一下查询语句的具体步骤:

  1. ADD_MONTHS(SYSDATE, -24)用于获取当前日期往前推两年的日期。
  2. ADD_MONTHS(SYSDATE, -12)用于获取当前日期往前推一年的日期。
  3. CONNECT BY LEVEL <= ADD_MONTHS(SYSDATE, -12) - ADD_MONTHS(SYSDATE, -24) + 1用于生成一个从往前推两年的日期到往前推一年的日期之间的连续日期序列。
  4. LAST_DAY(ADD_MONTHS(SYSDATE, -24) + LEVEL - 1)用于获取每个连续日期序列所在月份的最后一天。
  5. TO_CHAR(LAST_DAY(ADD_MONTHS(SYSDATE, -24) + LEVEL - 1), 'YYYY-MM-DD')用于将最后一天的日期格式化为'YYYY-MM-DD'的字符串。

这样,查询结果就是过去两年中每个月的最后一天的日期字符串。

在腾讯云的产品中,可以使用TencentDB for Oracle来进行Oracle数据库的管理和查询操作。具体产品介绍和链接地址如下:

  • 产品名称:TencentDB for Oracle
  • 产品介绍:TencentDB for Oracle是腾讯云提供的一种高性能、高可用、可弹性伸缩的关系型数据库解决方案,支持Oracle数据库的各种功能和特性。
  • 产品链接:TencentDB for Oracle
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Oracle Job创建及使用详解

Oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。 一、查询系统中的job,可以查询视图 --相关视图 select * from dba_jobs; select * from all_jobs; select * fromuser_jobs; -- 查询字段描述 /* 字段(列) 类型 描述 JOB NUMBER 任务的唯一标示号 LOG_USER VARCHAR2(30) 提交任务的用户 PRIV_USER VARCHAR2(30) 赋予任务权限的用户 SCHEMA_USER VARCHAR2(30) 对任务作语法分析的用户模式 LAST_DATE DATE 最后一次成功运行任务的时间 LAST_SEC VARCHAR2(8) 如HH24:MM:SS格式的last_date日期的小时,分钟和秒 THIS_DATE DATE 正在运行任务的开始时间,如果没有运行任务则为null THIS_SEC VARCHAR2(8) 如HH24:MM:SS格式的this_date日期的小时,分钟和秒 NEXT_DATE DATE 下一次定时运行任务的时间 NEXT_SEC VARCHAR2(8) 如HH24:MM:SS格式的next_date日期的小时,分钟和秒 TOTAL_TIME NUMBER 该任务运行所需要的总时间,单位为秒 BROKEN VARCHAR2(1) 标志参数,Y标示任务中断,以后不会运行 INTERVAL VARCHAR2(200) 用于计算下一运行时间的表达式 FAILURES NUMBER 任务运行连续没有成功的次数 WHAT VARCHAR2(2000) 执行任务的PL/SQL块 CURRENT_SESSION_LABELRAW MLSLABEL 该任务的信任Oracle会话符 CLEARANCE_HI RAW MLSLABEL 该任务可信任的Oracle最大间隙 CLEARANCE_LO RAW MLSLABEL 该任务可信任的Oracle最小间隙 NLS_ENV VARCHAR2(2000) 任务运行的NLS会话设置 MISC_ENV RAW(32) 任务运行的其他一些会话参数 */ -- 正在运行job select * fromdba_jobs_running; 其中最重要的字段就是job这个值就是我们操作job的id号,what 操作存储过程的名称,next_date 执行的时间,interval执行间隔 二、执行间隔interval运行频率

05
领券