dadianzi
作者dadianzi·2010-10-25 11:52
·

DB2学习笔记-存储过程

字数 4201阅读 1997评论 0赞 0
存储过程的作用:
Sql代码
  1. Creat procedure 存储过程名(in 参数名 数据类型,out 参数名 数据类型)  
  2.   
  3. Language 语言 (sql,java,c,.net)  
  4.   
  5. Specific 标识名  
  6.   
  7. Dynamic result sets 数量  
  8.   
  9. Determitation//not  
  10.   
  11. Begin  
  12.   
  13.    
  14. End  
Creat procedure 存储过程名(in 参数名 数据类型,out 参数名 数据类型) Language 语言 (sql,java,c,.net) Specific 标识名 Dynamic result sets 数量 Determitation//not Begin End
Sql代码
  1. Connect to sample@  
  2.   
  3. Create procedure pro(  
  4.   
  5. Put w char(20)  
  6.   
  7. )  
  8.   
  9. Language sql  
  10.   
  11. Begin  
  12.   
  13.        Declare f char(20);  
  14.   
  15.        Set f=’welcome’;  
  16.   
  17.        Set w=f;  
  18.   
  19. End@  
Connect to sample@ Create procedure pro( Put w char(20) ) Language sql Begin Declare f char(20); Set f=’welcome’; Set w=f; End@

解决DB21061E未初始化命令行环境问题:C:Documents and Settingsremy>db2cmd。


游标:

1.获得sql语句执行的结果,结果包括值所在的缓冲区域,定位,值的分析等。

2.Declare 游标名 cursor with hold

for sql 语句

Declare c1 cursor for select * from test

3.    open 游标名

       Fetch from 游标名 into 变量名

       Close 游标名  // 释放系统的缓冲区域空间

注意:  a:fetch 前必须要先open;

          B:open 表示为游标所存数据开始缓冲区域;

          C:游标取值方向永远是从第一条数据一次往下取值,不能够取上一条或几条数据;凡是open,此时游标的位置肯定指向第一条数据;

Open c1;

Fetch from c1 into temp;

Close c1;

Open c1;

              D:只要系统自动提交,等同于close;with hold.


依据你所输入的号码来查询test表中的数据。

Sql代码
  1. Connect to sample@  
  2.   
  3. drop table test@  
  4.   
  5. create table test (id int ,name char (20))@  
  6.   
  7. insert into test values(1,'张三')@  
  8.   
  9. insert into test values (2,'李四')@  
  10.   
  11. Create procedure view(  
  12.   
  13.        In i int,out vname char(20)  
  14.   
  15. )  
  16.   
  17. Language sql  
  18.   
  19. Begin  
  20.   
  21.        // 游标方式  
  22.   
  23.        // Declare c1 cursor for Select name from test where id =i;  
  24.   
  25.          Open c1;  
  26.   
  27.          Fetch from c1 into vname;  
  28.   
  29.          Close c1;  
  30.   
  31.        // 普通方式  
  32.   
  33. // declare temp char(20);  
  34.   
  35.   For temp as select name from test where id=i do  
  36.   
  37.   Set vname = temp.name  
  38.   
  39.   End for;  
  40.   
  41. end@  
Connect to sample@ drop table test@ create table test (id int ,name char (20))@ insert into test values(1,'张三')@ insert into test values (2,'李四')@ Create procedure view( In i int,out vname char(20) ) Language sql Begin // 游标方式 // Declare c1 cursor for Select name from test where id =i; Open c1; Fetch from c1 into vname; Close c1; // 普通方式 // declare temp char(20); For temp as select name from test where id=i do Set vname = temp.name End for; end@

命令行执行db2 call view(1,?)后,可取到i为1的vname值。

如果觉得我的文章对您有用,请点赞。您的支持将鼓励我继续创作!

0

添加新评论0 条评论

Ctrl+Enter 发表

作者其他文章

X社区推广