创建一个表循环插入某个月或整年的日期

2024-04-04 13:08

本文主要是介绍创建一个表循环插入某个月或整年的日期,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

--写查询或存储过程时,有时可能会需要创建一个中间表,比如日期,下面是循环插入当月所有日期和整年所有日期的SQL 

--创建会话级临时表用来存储日期,不过我这里日期存储的是varchar2 类型
CREATE GLOBAL TEMPORARY TABLE RQ(ID NUMBER PRIMARY KEY ,SJ VARCHAR2(20))
ON COMMIT PRESERVE ROWS
SELECT * FROM RQ--循环插入日期  插入当月的日期 
DECLARE 
C_I NUMBER :=1;
V_I NUMBER ;
V_FIRSTDAY VARCHAR2(20);
V_LASTDAY  VARCHAR(20);
BEGINSELECT TO_CHAR(SYSDATE,'YYYY-MM')||'-' INTO V_FIRSTDAY FROM DUAL;SELECT TO_CHAR(LAST_DAY(SYSDATE),'YYYY-MM-DD') INTO V_LASTDAY FROM DUAL;SELECT CEIL(LAST_DAY(SYSDATE)-TRUNC(SYSDATE,'MM'))+1 INTO V_I FROM DUAL;LOOPINSERT INTO RQ (ID,SJ) VALUES(C_I,V_FIRSTDAY||TO_CHAR(C_I));C_I:=C_I+1;EXIT WHEN C_I=V_I;END LOOP;END;--循环插入日期 插入某年的日期
DECLARE 
C_I NUMBER :=0;
V_I NUMBER ;
V_FIRSTDAY DATE;
V_LASTDAY  DATE;
BEGINSELECT TRUNC(TO_DATE('2015','YYYY'),'YYYY') INTO V_FIRSTDAY FROM DUAL;SELECT ADD_MONTHS(TRUNC(TO_DATE('2015','YYYY'),'YYYY'),12) INTO V_LASTDAY FROM DUAL;SELECT V_LASTDAY-V_FIRSTDAY INTO V_I FROM DUAL;LOOPINSERT INTO RQ (ID,SJ) VALUES(C_I,TO_CHAR(V_FIRSTDAY+C_I,'YYYY-MM-DD'));C_I:=C_I+1;EXIT WHEN C_I=V_I;END LOOP;END;

这篇关于创建一个表循环插入某个月或整年的日期的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/875855

相关文章

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

Java中的for循环高级用法

《Java中的for循环高级用法》本文系统解析Java中传统、增强型for循环、StreamAPI及并行流的实现原理与性能差异,并通过大量代码示例展示实际开发中的最佳实践,感兴趣的朋友一起看看吧... 目录前言一、基础篇:传统for循环1.1 标准语法结构1.2 典型应用场景二、进阶篇:增强型for循环2.

python如何创建等差数列

《python如何创建等差数列》:本文主要介绍python如何创建等差数列的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python创建等差数列例题运行代码回车输出结果总结python创建等差数列import numpy as np x=int(in

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可