一. 使用存储过程的好处

  1. 减少客户机与服务器之间的网络使用率,以及数据库锁定保持的时间

      应用程序通常在执行每个SQL语句都要跨网络两次,存储过程可以将SQL语句集中在一起,

    从而使得对于每一组SQL语句只需要跨网络两次。存储过程中集中在一起的SQL语句越多,

    网络的使用率和数据库锁定保持的时间就越低。通过减少网络使用率和数据库锁定的时间长短,

    就可以提高网络的总体性能并减少锁定争用问题。

二. 用于存储过程的语言

  在DB2的"开发中心",可以用Java或SQL来创建存储过程。

三. SQL存储过程

  1. 使用SQL过程语言来编写存储过程具有下列优点:

    a. 可以通过在"开发中心"中使用集成调试器来调试SQL存储过程

    b. 借助SQL存储过程,可以调用其它SQL过程,最多可以嵌套16层调用

    c. SQL存储过程运行速度快,因为它是作为已编译的例程来运行的

  2. SQL存储过程具有大小和参数限制,这取决于正在运行的DB2版本:

    a. 对于DB2 Windows版和UNIX版,在版本7和版本8中,SQL存储过程的最大大小是64KB

四. Java存储过程

   1. 使用Java语言来编写存储过程具有下列优点:

    a. 在Java的安全性限制之内,可以使用Java存储过程进行文件的输入/输出。SQL存储过程不支持

      文件的输入/输出。

五. 存储过程的基本语法 

create procedure db2Inst.proce1(
in "inParam" integer,
out "outParam" varchar(10)
)
specific "proce1"
language sql
dynamic result sets 1
not deterministic
external action
modifies sql data
old savepoint level begin
L1: begin
/*变量定义*/
declare inum integer default 0; /*变量赋值*/
set inum = 20; /*分支语句*/
if 条件1 then
...
elseif 条件2 then
...
else
...
end if; /*多分支语句case*/
case 变量名
when 变量值1 then
...
when 变量值2 then
...
else
...
end case; /*for循环*/
for 变量名 as 游标名或select 表达式
do
...
end for; /*while循环*/
while 条件表达式 do
...
end while; /*loop语句*/
insLoop:
loop
...
leave insLoop;/*中断循环*/
iterate insLoop;/*下一个循环*/
end loop; /*游标的使用方式一*/
/*定义游标*/
declare 游标名 cursor for select 语句;
/*打开游标*/
open 游标名;
/*取值*/
fetch 游标名 into 变量列表;
/*关闭游标*/
close 游标名; /*goto语句*/
goto fail;
...
success: return 0
fail: return -200 end L1; /*游标的使用方式二*/
/*游标的定义如果放在中间段,要用"begin...end;"段分割标志分割开*/
L2: begin
declare v_notfound integer default 0;
declare stmt statement;/*声明放游标的值 */
declare cur cursor with return for stmt;/*声明动态游标存储变量*/
declare continue handler for not found set v_notfound = 1; prepare stmt from qrySql;
open cur;
fetch cur into 变量列表;
close cur;
end L2; /*临时表*/
L3: begin
/*定义临时表*/
declare global temporary table session.tableName(
columnName integer
)
not logged with replace;/*不记录日志,没有则替换*/
/*操作临时表*/
insert into session.tableName values(columnValue);
end L3; /*取得行号*/
select rownumber() over() as rownum from tableName; /*解决like后跟一个字段*/
select * from table1 a
left join table2 b on locate(a.columnName,b.columnName)>0; end

六. 存储过程属性说明

procedureName:存储过程的名字,在同一个数据库的同一模式下,不能存在
存储过程名相同,参数数目相同的存储过程,即使参数的类型不同也不行 (in|out|inout paramName dataType, ...):传入参数
in:输入参数,out:输出参数,inout:作为输入输出参数
dataType:参数类型,可以接收SQL类型和创建的表,不支持long varchar,
long vargraphic,datalink,reference和用户自定义类型。 specific specificName:唯一的特定名称(别名),可以用存储过程名代替。
用于给存储过程添加注释用,但不能调用存储过程。如果不指定,则数据库
会自动生成一个yymmddhhmmsshhn时间戳的名字。 language sql:指定过程的主体用的是SQL语言 dynamic result sets integer:指定存储过程返回结果的最大数量,若小于实际返回数量,则db2返回警告 deterministic or not deterministic:表示存储过程是动态或者非动态的。
动态的返回的值是不确定的,非动态每次返回值都是相同的 external action or no external action:表示存储过程是否执行改变数据库状态的活动,
而不通过数据库管理器。默认是external action。如果指定为no external action,
则数据库会确定最佳优化方案。 contains sql, reads sql data, modifies sql data:指定存储过程中的SQL访问级别
contains sql:表示存储过程可以执行中,既不可读取SQL数据,也不可修改SQL数据。
reads sql data:表示存储过程可以执行中,可读取SQL,但不可修改SQL数据。
modifies sql data:表示存储过程可以执行任何SQL语句。可以对数据库中的数据进行
增加、删除和修改。 old savepoint level or new savepoint level:建立存储点(存储某个时候的数据),
old savepoint level是默认的存储点 called on null input:表示可以调用存储过程而不管任何的输入参数是否为NULL,并且,
任何的out或者inout参数可以返回一个NULL或者非空值。检验参数是否为NULL是在过程中进行的。 inherit special registers:表示继承专用寄存器 parameter ccsid:指定所有输出字符串数据的编码,默认为unicode编码数据库为:parameter ccsid unicode,
其他的数据库默认为:parameter ccsid 3 ascii

七. 存储过程调用另一存储过程,返回结果集

  1. 存储过程1:返回2个结果集

create procedure db2Inst.proc1()
language sql
result sets 2 P1:begin
declare c1 cursor with return to caller for select语句;
declare c2 cursor with return to caller for select语句; open c1;
open c2; ...
end P1

  2. 存储过程2:调用存储过程1,取得2个结果集

create procedure db2Inst.proc2()
language sql P1:begin
/*建立一个结果集数组*/
declare loc1,loc2 result_set_locator varying;
/*调用存储过程1,返回结果集*/
call proc1;
/*将返回结果集和结果集数组关联*/
associate result set locator(loc1,loc2) with procedure proc1;
/*将结果集数组进行分配*/
allocate cursor1 cursor for result set loc1;
allocate cursor2 cursor for result set loc2; /*直接从结果集中取值*/
fetch cursor1 into 变量列表;
close cursor1; ...
end P1

八. 结果集的返回类型  

create procedure db2Inst.proc3()
language sql
dynamic result sets 2
reads sql data begin
declare rs1 cursor with return to client for select语句;
declare rs2 cursor with return to caller for select语句;
open rs1;
open rs2;
end

  1. with return to client:表示由发出最初call语句的客户应用接收结果集,即使结果集由嵌套层次中的

    15层深的嵌套存储过程发出也是如此。

  2. with return to caller:表示由存储过程的调用者接收结果集,而不考虑调用者是否是另一个存储过程,

    还是客户应用。

九. 异常处理

  1. 声明异常处理器的语法如下,它会位于变量声明和游标声明之后:

    declare handlerType handler for condition

  2. handlerType异常处理器类型有以下几种:

    a. continue:在处理器操作完成之后,会继续执行产生这个异常语句之后的下一条语句

    b. exit:在处理器操作完成之后,存储过程会终止,并将控制返回给调用者

    c. undo:在处理器操作执行之前,DB2会回滚存储过程中执行的SQL操作。在处理器操作

      完成之后,存储过程会终止,并将控制返回给调用者。

  3. 异常的种类(condition)

    异常处理器可以处理基于特定SQLSTATE值的定制异常,或者处理预定义异常的类。

    预定义的3种异常:

      a. not found:标识导致SQLCODE值为+100或者SQLSTATE值为0200的异常。

        这个异常通常在select没有返回行的时候出现。

      b. sqlexception:标识导致SQLCODE值为负的异常

      c. sqlwarning:标识导致警告异常或者导致+100以外的SQLCODE正值的异常

  4. 异常处理器示例

    declare exit handler for sqlexception, sqlwarning set stmt = "aborted";

    declare undo handler for not found;

db2存储过程的更多相关文章

  1. DB2 存储过程创建、系统表

    前段时间做了数据表拆分,进行数据迁移,用到一些SQL命令,语句记录下来 db2look是DB2用于生成数据库DDL语句的一个工具: 命令:db2look -d DBname -a -e -p -i u ...

  2. DB2存储过程语法规则

    如何声明一个存储过程CREATE PROCEDURE 存储过程名(IN 输入变量名 输入变量类型,OUT 输出变量名 输出变量类型)紧跟其后的是存储过程属性列表            常用的有:LAN ...

  3. linux命令行执行db2存储过程

    存储过程代码如下: CREATE PROCEDURE proc_sum2(IN n INT,OUT sum INT,OUT j INT) BEGIN DECLARE i INT; ; ; ; WHIL ...

  4. db2 存储过程迁移方法

    大家在迁移数据库时,存储过程一般也要迁移过去,但一般有两个问题: 1. 非常多存储过程有先后关系(存储过程调用存储过程),假设存储过程数量少,还能手动操作.假设量大,那真是要疯了. 2. 存储过程过大 ...

  5. 通过DbVisualizer 工具运行DB2存储过程实现INSERT语句主键自增造数

    1.需求简介 最近开发人员需要进行一批数据进行生产上SQL语句耗时过长问题的验证与优化.所以在性能测试库中批量建造数据,由于交易本身业务逻辑过于复杂以及需要各种授权,最后决定采用插表的方式完成. 2. ...

  6. db2存储过程迁移

    一.导出存储过程 EXPORT TO D:/PROCUDURE/procudure.del OF del MODIFIED BY LOBSINFILE SELECT 'SET CURRENT SCHE ...

  7. db2 存储过程参数传递--字段类型转换产生的问题

    修改之前的脚本 select count(*) from dbdk.dtdkg010 A left join DBDK.DTDKG070 D ON D.PAY_NO = A.PAY_NO LEFT J ...

  8. 怎样提高DB2存储过程性能

    高性能的SQL过程是数据库开发人员所追求的,我将不断把学到的,或在实际开发中用到的一些提高SQL过程性能的技巧整理出来,温故而知新. 1,在只使用一条语句即可做到时避免使用多条语句 让我们从一个简单的 ...

  9. db2 -- 存储过程01

    接下来项目在技能可能偏向数据库方面,补习下. 学习写第一个db2在存储过程,记录下. ---- stored procedures code CREATE OR REPLACE PROCEDURE & ...

随机推荐

  1. 配置WCF Test Client

    用vs2010建立了一个wcf项目,通过F5直接运行那服务文件,就出现了一个”The dependent tool 'svcutil.exe' is not found“, , 之后想通过“tool- ...

  2. Bootstrap源码分析之transition、affix

    一.Transition(过滤) 作为一个基础支持的组件,被其他组件多次引用.实现根据浏览器支持transition的能力,然后绑定动画的结束事件:首先:创建一个Element:然后:迭代查看此元素支 ...

  3. 使用 FocusPoint.js 实现图片的响应式裁剪

    通常网站的布局都不是单一的.例如图像在电脑.平板和智能手机上可能显示的形状是不同的.特别是如果你使用的是全屏图像,在你必须使用相同的图像文件的情况下,你的主题可能会被截断或完全缺失,或者看起来很尴尬. ...

  4. 你应该知道的10个奇特的 HTML5 单页网站

    网页设计师努力寻找新的方式来展现内容.其中一个大的趋势是单页网站,现在被世界上的一些大的品牌广泛采用,使用它们来为用户提供一个快速,干净和简单的而且​​美丽的网站. 下面是10个令人惊叹的单页 H​​ ...

  5. Sitecake – 可视化编辑,所见即所得的 CMS

    Sitecake 是一个易于使用的,用于制作小型网站的 CMS(内容管理系统).提供所见即所得.拖拽操作的编辑器.只需要安装标准的虚拟主机包(Web服务器和 PHP 5.4+)就可以了.Sitecak ...

  6. Java2_J2EE、J2SE和J2ME的区别

    解析J2EE.J2SE.J2ME.JDK的区别       本文向大家简单介绍一下JDK.J2EE.J2SE.J2ME概念及区别,J2EE,J2SE,J2ME是java针对不同的的使用来提供不同的服务 ...

  7. 异常之Tomcat7.0服务器无法发布项目

    今天突然就不能发布tomcat 7.0服务器了,并弹出对话框,报出如下错误: Cannot acquire J2EEFlexProjDeployable object for module test ...

  8. javascript 对象初探 (四)--- 内建对象之旅之Array

     我们不要去纠结神马是内建对象,神马是內建构造器.到后来你们便会发现其实她们都是对象. Array()是一个构建数组的內建构造器函数: var arr = new Array(); 与下面的是等效的: ...

  9. Android基础面试题

    1. 请描述一下Activity 生命周期. 答: 如下图所示.共有七个周期函数,按顺序分别是: onCreate(), onStart(), onRestart(), onResume(), onP ...

  10. sharepoint:找不到位于 http://XX.XX.XX.XX 的 Web

    自己写了个sharepoint的webservice,发不到IIS上后报错: System.IO.FileNotFoundException: 找不到位于 http://XX.XX.XX.XX 的 W ...