(^o^)/~完美 发表于 2016-11-18 09:18:05

DB2存储过程语法

  原文 http://zhuyuehua110.blog.163.com/blog/static/918619420107953555989/
  语法:   
CREATE PROCEDURE <schema-name>.<procedure-name> (参数) [属性] <语句>   

--参数:SQL PL 存储过程中有三种类型的参数:   
   IN:输入参数(默认值,也可以不指定)   
   OUT:输出参数   
   INOUT:输入和输出参数   

--属性   
1、LANGUAGE SQL   
指定存储过程使用的语言。LANGUAGE SQL 是其默认值。还有其它的语言供选择,比如Java 或者C,可以将这一属性值分别设置为LANGUAGE JAVA 或者 LANGUAGE C。   

2、DYNAMIC RESULT SETS <n>   
如果您的存储过程将返回n 个结果集,那么需要填写这一选项。   

3、SPECIFIC my_unique_name   
赋给存储过程一个唯一名称,如果不指定,系统将生成一个惟一的名称。一个存储过程是可以被重载的,也就是说许多个不同的存储过程可以使用同一个名字,但这些存储过程所包含的参数数量不同。通过使用SPECIFIC 关键字,您可以给每一个存储过程起一个唯一的名字,这可以使得我们对于存储过程的管理更加容易。例如,要使用SPECIFIC 关键字来删除一个存储过程,您可以运行这样的命令:DROP SPECIFIC PROCEDURE。如果没有使用SPECIFIC 这个关键字,您将不得不使用DROP PROCEDURE 命令,并且指明存储过程的名字及其参数,这样DB2 才能知道哪个被重载的存储过程是您想删除的。   

4、SQL 访问级别   
NO SQL:存储过程中不能有 SQL 语句   
CONTAINS SQL:存储过程中不能有可以修改或读数据的 SQL 语句   
READS SQL:存储过程中不能有可以修改数据的 SQL 语句   
MODIFIES SQL:存储过程中的 SQL 语句既可以修改数据,也可以读数据   
   默认值是 MODIFIES SQL,一个存储过程不能调用具有更高 SQL 数据访问级别的其他存储过程。例如,被定义为 CONTAINS SQL 的存储过程可以调用被定义为 CONTAINS SQL 或 NO SQL 的存储过程。但是这个存储过程不能调用被定义为 READS SQL DATA 或 MODIFIES SQL 的其他存储过程。   


--语句   
可以是一条单独的语句或者是一组由BEGIN ... END 复合语句
页: [1]
查看完整版本: DB2存储过程语法