CREATE OR REPLACE PROCEDURE LOY.TEST1 ( )
---此处忽略就行了,这个是db2自动为我们生成的
SPECIFIC SQL180919100638350
LANGUAGE SQL
NOT DETERMINISTIC
EXTERNAL ACTION
MODIFIES SQL DATA
CALLED ON NULL INPUT
INHERIT SPECIAL REGISTERS
OLD SAVEPOINT LEVEL
--创建存储过程
BEGIN
--以下是生成变量,其实没啥说的
DECLARE custNo VARCHAR(50);
DECLARE cardNo VARCHAR(50);
DECLARE mainFlag VARCHAR(50);
DECLARE mainCardNo VARCHAR(50);
DECLARE orgNo VARCHAR(50);
DECLARE acct_open_date VARCHAR(50);
DECLARE status VARCHAR(50);
DECLARE createDate VARCHAR(50);
DECLARE cardno_linshi VARCHAR(50);
DECLARE sql_linshi VARCHAR(100);
DECLARE stuInfor_end INTEGER DEFAULT 0;
DECLARE num INTEGER DEFAULT 0;
DECLARE sum INTEGER DEFAULT 0;
DECLARE countSum INTEGER DEFAULT 0;
----声明游标,此处加了关键之 with hold
---这个关键词的含义是,出现了某条记录异常的时候游标继续执行,不加这个参数则游标会
---停止。但是亲测好像出了异常都会停止,该参数确实意义不大,不过你加上就行了。明白了----吗?
DECLARE stuInfor CURSOR with hold FOR (
select
SC_BIZ_DEPOSIT_PERSON.CST_ID as CUST_NO,
CRD_AR_ID as CARD_NO,
as MAIN_FLAG,
as MAIN_CARD_NO,
OPNG_OU_IP_ID as ORG_NO,
EFC_DT as ACCT_OPEN_DATE,
as status,
20180919 as create_date
from SC_BIZ_DEPOSIT_PERSON where length(CRD_AR_ID)!=0
);
--这里到下面的ROLLBACK的end; 此处是固定模式(可以直接黏贴到你的存储过程中),意思是游标结束以后,设置我们的标志为1
--1,否则它一直是定义的时候的值为0.
DECLARE CONTINUE HANDLER FOR NOT FOUND
begin
SET stuInfor_end = 1;--
end;
DECLARE EXIT HANDLER FOR SQLEXCEPTION
begin
ROLLBACK;--
end;
---到上面这是固定模式
open stuInfor;--当定义完游标后,游标需要打开后使用
---打开游标设置到自己的变量中,这几个变量是自己定义的,也就是有几个字段,定义几个变---量,注意顺序不能改变
FETCH stuInfor INTO custNo,cardNo,mainFlag,mainCardNo,orgNo,acct_open_date,status,createDate;--
WHILE stuInfor_end = 0 DO
---fetch first 1 rows only是db2的函数,意思是取出第一条数据
---select into 意思是设置到查询的结果到变量中,注意此处必须返回一条数据。否则报错。
---存储过程报错直接就退出了,不会提示错误,明白吗?
select count(1) into countSum from DB_DEBIT_CARD
where card_No=cardNo fetch first 1 rows only;
---注意if then 和end if;为固定语法
--if (条件) then
--elseif(条件) then
--else
---end if;
if countSum=0 then
insert into DB_DEBIT_CARD ( CUST_NO, CARD_NO,
MAIN_FLAG, MAIN_CARD_NO, ORG_NO,
ACCT_OPEN_DATE, STATUS, CREATE_DATE
) values (custNo,cardNo,mainFlag,mainCardNo,orgNo,acct_open_date,status,createDate);
end if;
---每次要重新设置值,此处千万注意。
FETCH stuInfor INTO custNo,cardNo,mainFlag,mainCardNo,orgNo,acct_open_date,status,createDate;
----设置变量一定要用set,此处是坑
set num=num+1;
set sum= MOD(num,1000);
if(sum=0) then
commit;
end if;
END WHILE;--
CLOSE stuInfor;--关闭游标
END;
使用习惯了oracle,突然来了db2还真有点不适应。
20100920 -于
江西南昌农商行管理处
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
主要特点:
类语言主要提供以下功能,让用户可以设计出符合引用需求的程序:
1)、变量说明
2)、ANSI(美国国家标准化组织)兼容的SQL命令(如Select,Update….)
3)、一般流程控制命令(if…else…、while….)
4)、内部函数
存储过程的优点:
(1) .存储过程的能力大大增强了SQL语言的功能和灵活性。存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。
(2) .可保证数据的安全性和完整性。
(3) .通过存储过程可以使没有权限的用户在控制之下间接地存取数据库,从而保证数据的安全。
(4) .通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性。
(5) .在运行存储过程前,数据库已对其进行了语法和句法分析,并给出了优化执行方案。这种已经编译好的过程可极大地改善SQL语句的性能。由于执行SQL语句的大部分工作已经完成,所以存储过程能以极快的速度执行。
(6) .可以降低网络的通信量。
(7) .使体现企业规则的运算程序放入数据库服务器中,以便:
(8) .集中控制。
(9) .当企业规则发生变化时在服务器中改变存储过程即可,无须修改任何应用程序。企业规则的特点是要经常变化,如果把体现企业规则的运算程序放入应用程序中,则当企业规则发生变化时,就需要修改应用程序工作量非常之大(修改、发行和安装应用程序)。如果把体现企业规则的运算放入存储过程中,则当企业规则发生变化时,只要修改存储过程就可以了,应用程序无须任何变化。