oracle 存储过程基础
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 存储过程基础的更多相关文章
- oracle 存储过程 基础
差不多一年没写过存储过程,最近要写,发现基本忘了,google一番之后,觉得很有必要把基础的东西写下来备忘. 语句块定义: decalre -- 变量声明 var1 ); -- 仅声明 var2 ) ...
- Oracle存储过程基础
http://blog.sina.com.cn/s/blog_67e424340100iyg1.html
- Oracle 存储过程学习笔记
1.存储过程简单实例 CREATE OR REPLACE PROCEDURE 存储过程名称 (参数in,参数out) AS -- 变量声明,每个声明用分号结束.可以在声明的同时初始化 name ); ...
- Oracle存储过程基本语法及基础教程
存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE ...
- Oracle数据库基础知识
oracle数据库plsql developer 目录(?)[-] 一 SQL基础知识 创建删除数据库 创建删除修改表 添加修改删除列 oracle cascade用法 添加删除约束主键外 ...
- oracle存储过程实例
oracle存储过程实例 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的P ...
- [转]使用ADO.NET访问Oracle存储过程
本文转自:http://www.cnblogs.com/datasky/archive/2007/11/07/952141.html 本文讨论了如何使用 ADO.NET 访问 Oracle 存储过程( ...
- oracle存储过程的例子
oracle存储过程的例子 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的 ...
- Crontab定时执行Oracle存储过程
Crontab定时执行Oracle存储过程 需求描述 我们有一个Oracle的存储过程,里面是每个月需要执行一下,生成报表,然后发送给业务部门,这一个功能我们有实现在系统的前台界面(如图1-1),但是 ...
随机推荐
- 生成跨语言的类型声明和接口绑定的工具(Djinni )
Djinni 是一个用来生成跨语言的类型声明和接口绑定的工具,主要用于 C++ 和 Java 以及 Objective-C 间的互通. 示例接口定义文件: # Multi-line comments ...
- Quartz Cron 表达式
Cron 表达式包括以下 7 个字段 格式: [秒] [分] [小时] [日] [月] [周] [年] 说明 是否必填 允许填写的值 允许的通配符 秒 是 - , - * / 分 是 - , - * ...
- 【UOJ】【UR #2】猪猪侠再战括号序列(splay/贪心)
http://uoj.ac/problem/31 纪念伟大的没有调出来的splay... 竟然那个find那里写错了!!!!!!!!!!!!! 以后要记住:一定要好好想过! (正解的话我就不写了,太简 ...
- POJ 3691 DNA repair(AC自动机+DP)
题目链接 能AC还是很开心的...此题没有POJ2778那么难,那个题还需要矩阵乘法,两个题有点相似的. 做题之前,把2778代码重新看了一下,回忆一下当时做题的思路,回忆AC自动机是干嘛的... 状 ...
- libtiff 生成48位色tif图片
BOOL CTifImage_48Bits::BitmapConvertTo48BitsTif(CString strImagePath, int nWidth, int nHeight, int n ...
- ASP.NET RepeatLayout 属性
定义和用法 RepeatLayout 属性用于设置或获取如何显示在 CheckBoxList 中的项目. 语法 <asp:CheckBoxList RepeatLayout="mode ...
- 【新产品发布】发布STM8S 核心板
搞了一些STM8的核心板供大家把玩,先上几张图: 物品购买地址: http://item.taobao.com/item.htm?spm=686.1000925.1000774.17.5GMO5M&a ...
- Tortoise SVN 不显示 Log Message 具体信息的解决方法
今天加入新项目,在 Tortoise SVN Check out 完项目之后,发现右键 show log 不显示 Log Message 的具体信息: 因为是新加入的项目,问了原来负责这个项目的同事, ...
- Thinkphp 不显示生成的验证码 【转载】
在调用验证码之前加上 ob_clean(); 不显示验证码的代码: public function verify(){ $verify = new \Think\Verify(); $verify-& ...
- cURL 学习笔记与总结(1)概念
概念: cURL(Client URL Library Functions)is a command line tool for transfering data with URL syntax(使用 ...