db2存储过程实例,原创

2026年01月21日/ 浏览 9

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) .当企业规则发生变化时在服务器中改变存储过程即可,无须修改任何应用程序。企业规则的特点是要经常变化,如果把体现企业规则的运算程序放入应用程序中,则当企业规则发生变化时,就需要修改应用程序工作量非常之大(修改、发行和安装应用程序)。如果把体现企业规则的运算放入存储过程中,则当企业规则发生变化时,只要修改存储过程就可以了,应用程序无须任何变化。

picture loss