create or replace procedure update_CarryoverArchivers(bizsysname in varchar,

year       in number default 2015) is

begin

declare

num    number;

objSql varchar(1000);

i      number;

begin

num := -1;

select count(*) into num from bd_doc_type where iyear = year;

if num >= 1 then

null;

end if;

if num = 0 then

objSql := 'insert into BD_DOC_TYPE select sdoc_type_code,sdoc_type_name,sshort_text,smudole,' || year ||

',stype,sprinttemplatecode, ''' || year ||

'/01/01 16:51:32'' from BD_DOC_TYPE where iyear=' ||

to_char(year - 1);

/*dbms_output.put_line(objSql);*/

execute immediate objSql;

end if;

num := -1;

select count(*) into num from sm_billtype where iyear = year;

if num >= 1 then

null;

end if;

if num = 0 then

objSql := 'insert into sm_billtype select scode,sname,sbilltypetitle,' || year ||

',''' || year ||

'/12/12 15:03:40'' from sm_billtype where iyear=' ||

to_char(year - 1);

/* dbms_output.put_line(objSql);*/

execute immediate objSql;

end if;

num := -1;

select count(*) into num from bd_fyearstruct_m where iyear = year;

if num >= 1 then

null;

end if;

if num = 0 then

objSql := 'insert into ' || bizsysname || '.BD_FYEARSTRUCT_M (IYEAR, DY_STARTDATE, DY_ENDDATE, IPERIODNUM, BCLOSED, BACTIVEYEAR, TS)

values (' || year || ', ''' || year || '0101'', ''' || year ||

'1231'', 12, ''n'', ''Y'', ''' || year ||

'/01/01 20:33:38'')';

dbms_output.put_line(objSql);

execute immediate objSql;

dbms_output.put_line('xxx');

end if;

num := -1;

i   := 1;

select count(*) into num from bd_fyearstruct_s where iyear = year;

if num >= 1 then

null;

end if;

if num = 0 then

while i <= 12 loop

objSql := ' insert into ' || bizsysname || '.BD_FYEARSTRUCT_S (SPERIODCODE, IYEAR, DP_BEGINDATE, DP_ENDDATE, SPERIODNAME, BCLOSED, BACITVE, TS)

values (''' || year || '-0' || to_char(i) || ''',' || year ||

', ''' || year || '0' || to_char(i) ||

'01'',to_char(add_months(to_date(''' || year || '0' || to_char(i) ||

'01'', ''yyyymmdd''), 1)-1,''yyyymmdd''),''第' || to_char(i) ||

'期'', ''N'', null, ''1999/05/25 11:33:53'') ';

dbms_output.put_line(objSql);

execute immediate objSql;

i := i + 1;

end loop;

end if;

num := -1;

select count(*) into num from sm_billrule where iyear = year;

dbms_output.put_line(num);

if num >= 1 then

null;

end if;

if num = 0 then

objSql := 'insert into sm_billrule select SID, SBILLTYPECODE, BIFSHOWBILLTITLE, BYEAR, BMONTH, BDAY, BIFORDERNUMBER, INUMBERLEN, BIFSHOWOBJID, SPERIODCODE, SCORPCODE,' || year ||

' from sm_billrule where iyear=' || to_char(year - 1);

dbms_output.put_line(objSql);

execute immediate objSql;

end if;

commit;

Exception

When others then

dbms_output.put_line('你出错了'||sqlcode||sqlerrm);

Rollback;

end;

end update_CarryoverArchivers;

---------

存储过程的执行

begin

update_CarryoverArchivers;

end;

oracle 存储过程基础的更多相关文章

  1. oracle 存储过程 基础

    差不多一年没写过存储过程,最近要写,发现基本忘了,google一番之后,觉得很有必要把基础的东西写下来备忘. 语句块定义: decalre -- 变量声明 var1 ); -- 仅声明 var2 ) ...

  2. Oracle存储过程基础

    http://blog.sina.com.cn/s/blog_67e424340100iyg1.html

  3. Oracle 存储过程学习笔记

    1.存储过程简单实例 CREATE OR REPLACE PROCEDURE 存储过程名称 (参数in,参数out) AS -- 变量声明,每个声明用分号结束.可以在声明的同时初始化 name ); ...

  4. Oracle存储过程基本语法及基础教程

    存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE ...

  5. Oracle数据库基础知识

    oracle数据库plsql developer   目录(?)[-] 一     SQL基础知识 创建删除数据库 创建删除修改表 添加修改删除列 oracle cascade用法 添加删除约束主键外 ...

  6. oracle存储过程实例

    oracle存储过程实例 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的P ...

  7. [转]使用ADO.NET访问Oracle存储过程

    本文转自:http://www.cnblogs.com/datasky/archive/2007/11/07/952141.html 本文讨论了如何使用 ADO.NET 访问 Oracle 存储过程( ...

  8. oracle存储过程的例子

    oracle存储过程的例子 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的 ...

  9. Crontab定时执行Oracle存储过程

    Crontab定时执行Oracle存储过程 需求描述 我们有一个Oracle的存储过程,里面是每个月需要执行一下,生成报表,然后发送给业务部门,这一个功能我们有实现在系统的前台界面(如图1-1),但是 ...

随机推荐

  1. setTimeout()和setInterval() 何时被调用执行

    定义 setTimeout()和setInterval()经常被用来处理延时和定时任务.setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式,而setInterval()则可以在每隔 ...

  2. [简单]poi word2007表格按模版样式填充行数据

    主要实现了按照模版行的样式填充数据,针对的是动态数据,静态数据可以直接替换变量实现,先说下缺点:1)暂未实现特殊样式填充(如列合并(跨行合并)),只能用于普通样式(如段落间距 缩进 字体 对齐)2)数 ...

  3. Solve problem 'SURF' is not a member of 'cv'

    SIFT and SURF were moved to nonfree module. You need to add #include <opencv2/nonfree/nonfree.hpp ...

  4. IplImage 与 QImage 相互转换

    在使用Qt和OpenCV编程时,对于它们各自的图像类QImage和IplImage难以避免的需要互相之间的转换,下面我们就来看它们的相互转换. 1. QImage 转换为 IplImage IplIm ...

  5. 【iHMI43真彩液晶模块】发布新版 DEMO 软件包,版本号为 0.14

    新版DEMO软件包主要在以下几个方面进行了改进: 1.改进触摸算法,使用链表注册模式:注册触摸按键后:用户只需要处理事件(event)就行了,其他都由系统完成: 2.改进systick 和 usart ...

  6. 移动Web应用开发入门指南——兼容篇

    兼容篇 兼容篇是我最想写的一部分,在这之前也总结过很多关于移动开发的兼容问题与解决方案.对于移动Web开发来说,兼容是开发重心,通常要花费30%甚至更多的时间去处理一些兼容问题,甚至时间花掉了,问题依 ...

  7. [kuangbin带你飞]专题八 生成树 - 次小生成树部分

    百度了好多自学到了次小生成树 理解后其实也很简单 求最小生成树的办法目前遇到了两种 1 prim 记录下两点之间连线中的最长段 F[i][k] 之后枚举两点 若两点之间存在没有在最小生成树中的边 那么 ...

  8. PHP 开发 APP 接口学习笔记与总结 - [ Linux ] 定时任务

    定时任务可以使用 crontab 命令来设定: crontab -e #编辑某个用户的cron 服务 crontab -l  #列出某个用户cron 服务的详细内容 crontab -r  #删除某个 ...

  9. jQuery Ajax 确定 form 表单 submit 提交成功

    使用 jQuery 提交表单,可以使用 同步方式(async: false). a.html 是 html 文件,a.php 是服务端文件,把 a.html 中表单的数据提交到 a.php 中,在提交 ...

  10. PHP-FPM + Nginx: 502错误

    /etc/php5/fpm/pool.d/www.conf 里面找到这样一段代码: listen = 127.0.0.1:9000 在这上面代码的下面添加一行: listen = /var/run/p ...