文档章节

oracle存储过程

开源中国-总书记
 开源中国-总书记
发布于 2016/07/15 15:39
字数 249
阅读 10
收藏 0

CREATE OR REPLACE 
PROCEDURE P_REPOST_WEEK_QF (STARTDATE in varchar2)IS
                FIRSTDAYDATE  DATE;
                LASTDAYDATE  DATE; 
                MONDAY DATE; 
                SUNDAY DATE; 
                STARTHALF DATE;
                ENDHALF   DATE;
                MAXDATE DATE;
                I INTEGER;
                J INTEGER;
                YEAR INTEGER;
BEGIN
            SELECT TO_DATE(STARTDATE,'yyyyMMdd') INTO FIRSTDAYDATE FROM DUAL;
            SELECT LAST_DAY(ADD_MONTHS(FIRSTDAYDATE,11)) INTO LASTDAYDATE FROM DUAL;
            MONDAY:=FIRSTDAYDATE;
      MAXDATE:=MONDAY;
            SELECT TRUNC(MONDAY,'iw') INTO SUNDAY FROM DUAL;    
            SELECT substr(STARTDATE, 0, 4) INTO YEAR FROM DUAL;
            I:=1;
            J:=1;
            WHILE (MAXDATE <= LASTDAYDATE) LOOP
                    SELECT TRUNC(SUNDAY,'iw')+6 INTO MONDAY FROM DUAL;
                    SELECT TRUNC(MONDAY,'iw')+6 INTO MAXDATE FROM DUAL;
                    SELECT TRUNC(SUNDAY,'iw')+2 INTO ENDHALF FROM DUAL;
                    SELECT TRUNC(SUNDAY,'iw')+3 INTO STARTHALF FROM DUAL;
                    IF MAXDATE>LASTDAYDATE 
                         THEN
                             return;
                    END IF;
                    INSERT INTO REPORT_WEEK_HALF(WD_YEAR,WD_NATURAL_WEEK,WD_START_DATE,WD_END_DATE)VALUES
                    (YEAR,J,to_char(SUNDAY,'yyyyMMdd'),to_char(ENDHALF,'yyyyMMdd'));

                    J:=J+1;
                    INSERT INTO REPORT_WEEK_HALF(WD_YEAR,WD_NATURAL_WEEK,WD_START_DATE,WD_END_DATE)VALUES
                    (YEAR,J,to_char(STARTHALF,'yyyyMMdd'),to_char(MONDAY,'yyyyMMdd'));

                    INSERT INTO REPORT_WEEK_ALL(WD_YEAR,WD_NATURAL_WEEK,WD_START_DATE,WD_END_DATE)VALUES 
                    (YEAR,I,to_char(SUNDAY,'yyyyMMdd'),to_char(MONDAY,'yyyyMMdd'));    
                    
                    SELECT TRUNC(SUNDAY,'iw')+7 INTO SUNDAY FROM DUAL;
                    I:=I+1;
                    J:=J+1;
                END LOOP;
                COMMIT;
END P_REPOST_WEEK_QF;
 

© 著作权归作者所有

共有 人打赏支持
开源中国-总书记
粉丝 5
博文 4
码字总数 439
作品 0
青岛
私信 提问

暂无文章

码云项目100,水一发

简单回顾一下: 早期构想最多的,是希望能将PHP一些类和编码分区做得更细,所以很多尝试。但不得不说,PHP的功能过于单一,是的,也许写C/C++扩展,可以解决问题,那我为什么不用C#或者Golan...

曾建凯
30分钟前
1
0
Spring应用学习——AOP

1. AOP 1. AOP:即面向切面编程,采用横向抽取机制,取代了传统的继承体系的重复代码问题,如下图所示,性能监控、日志记录等代码围绕业务逻辑代码,而这部分代码是一个高度重复的代码,也就...

江左煤郎
今天
4
0
eclipse的版本

Eclipse各版本代号一览表 Eclipse的设计思想是:一切皆插件。Eclipse核心很小,其它所有功能都以插件的形式附加于Eclipse核心之上。 Eclipse基本内核包括:图形API(SWT/Jface),Java开发环...

mdoo
今天
3
0
SpringBoot源码:启动过程分析(一)

本文主要分析 SpringBoot 的启动过程。 SpringBoot的版本为:2.1.0 release,最新版本。 一.时序图 还是老套路,先把分析过程的时序图摆出来:时序图-SpringBoot2.10启动分析 二.源码分析 首...

Jacktanger
今天
4
0
小白带你认识netty(二)之netty服务端启动(上)

上一章 中的标准netty启动代码中,ServerBootstrap到底是如何启动的呢?这一章我们来瞅下。 server.group(bossGroup, workGroup);server.channel(NioServerSocketChannel.class).optio...

天空小小
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部