文档章节

DB2 从命令行创建SQL存储过程

Goopand
 Goopand
发布于 2015/04/16 15:50
字数 627
阅读 35
收藏 0

从命令行创建 SQL 过程

开始之前

  • 用户必须具有对 SQL 过程执行 CREATE PROCEDURE 语句所需的特权。

  • 执行过程的 SQL 过程体内包括的所有 SQL 语句的特权。

  • SQL 过程的 CREATE PROCEDURE 语句中引用的数据库对象必须存在,才能执行该语句。

过程

  • 对命令行处理器 (DB2® CLP) 选择缺省终止符以外的备用终止符,以在下一步中要预编译的脚本中使用,缺省终止符为分号(“;”)。

    CLP 必须能够区分出现在例程体的 CREATE 语句内的 SQL 语句结尾和 CREATE PROCEDURE 语句本身的结尾。分号字符必须用于在 SQL 例程体中终止 SQL 语句,所选备用终止符应该用于终止 CREATE 语句及可能包含在 CLP 脚本中的任何其他 SQL 语句。

    例如,在以下 CREATE PROCEDURE 语句中,“at;”符号(“@”)用作 DB2 CLP 脚本 myCLPscript.db2 的终止符:

        CREATE PROCEDURE UPDATE_SALARY_IF
        (IN employee_number CHAR(6), IN rating SMALLINT)
        LANGUAGE SQL
        BEGIN
          DECLARE not_found CONDITION FOR SQLSTATE '02000';
          DECLARE EXIT HANDLER FOR not_found
             SIGNAL SQLSTATE '20000' SET MESSAGE_TEXT = 'Employee not found';
    
          IF (rating = 1)
            THEN UPDATE employee
              SET salary = salary * 1.10, bonus = 1000
              WHERE empno = employee_number;
          ELSEIF (rating = 2)
            THEN UPDATE employee
              SET salary = salary * 1.05, bonus = 500
              WHERE empno = employee_number;
          ELSE UPDATE employee
              SET salary = salary * 1.03, bonus = 0
              WHERE empno = employee_number;
          END IF;
        END
    @
  • 使用以下 CLP 命令从命令行运行包含 CREATE PROCEDURE 语句的 DB2 CLP 脚本:

    db2 -td terminating-character -vf CLP-script-name

    其中 终止符 是在要运行的 CLP 脚本文件 CLP-脚本名 中使用的终止符。

    DB2 CLP 选项 -td 指示将使用终止符复位 CLP 终止符缺省值。-vf 指示将使用 CLP 的可选冗余(-v)选项,这会导致脚本中的每个 SQL 语句或命令运行时显示到屏幕上,同时显示执行这些语句或命令所生成的输出。-f 选项指示命令的目标为文件。

    要运行第一步中显示的特定脚本,请从系统命令提示符发出以下命令:

    db2 -td@ -vf myCLPscript.db2

相关参考:
CREATE FUNCTION(SQL 标量、表或行)语句

CREATE PROCEDURE (SQL) 语句

CREATE TYPE(结构化)语句


注意事项&小结:

由于db2look默认的分隔符是分号(;),而导出的存储过程之间也是以分号相隔。

为了db2命令行(CLP)从文件读取ddl编译存储过程,需要以一个非分号的分隔符,来分隔不同的存储过程,一般是@符放在END后面。




本文转载自:http://www-01.ibm.com/support/knowledgecenter/SSEPGG_9.7.0/com.ibm.db2.luw.apdv.sqlpl.doc/doc/t00...

共有 人打赏支持
Goopand
粉丝 8
博文 386
码字总数 193034
作品 0
朝阳
处理 DB2 数据 SQL 过程和用户定义的函数

创建和调用 SQL 过程 SQL 过程 是过程体用 SQL 编写的过程。过程体包含 SQL 过程的逻辑。它可以包含变量声明、条件处理、流控制语句和 DML。可以在复合语句(compound statement) 中指定多个...

范大脚脚
2017/11/12
0
0
使用Rational Data Architect v6.1构建,测试,部署DB2 SAMPLE数据库

概述 我们的场景是一个 DB2 UDB 的端到端的任务流,您在其中开发和调试一个 SQL 的存储过程。开始建立一个到 DB2 LUW 数据库的连接,该数据库提供数据开发工程的环境,在其中您将开发一个过程...

晨曦之光
2012/03/09
0
0
c++利用SqlApi访问SqlServer数据库(存储过程篇)

一、SqlApi介绍 SqlApi++是一个为访问Sql数据库而编写的库。支持对Oracle, SQL Server, DB2, Sybase, Informix, InterBase, SQLBase, MySQL, PostgreSQL, SQLite, ODBC数据库的访问。他提供简...

moki_oschina
2013/12/25
0
0
DBeaver 4.2.4 发布,数据库管理工具

DBeaver 4.2.4 发布了。DBeaver 是一个通用的数据库管理工具和 SQL 客户端,支持 MySQL, PostgreSQL, Oracle, DB2, MSSQL, Sybase, Mimer, HSQLDB, Derby, 以及其他兼容 JDBC 的数据库。 更新...

达尔文
2017/10/30
1K
8
db2 调用存储过程创建文件 报DB21005E,求指教

存储过程创建语句: CREATE OR REPLACE PROCEDURE "JMSI"."LY05_SC" ( IN PI_SHNY VARCHAR(6) , OUT PO_FHZ VARCHAR(50), OUT PO_MSG VARCHAR(500)) DYNAMIC RESULT SETS 1 SPECIFIC LY05_SC......

钟小华
2012/05/26
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

读书(附电子书)|小狗钱钱之白色的拉布拉多

关注公众号,在公众号中回复“小狗钱钱”可免费获得电子书。 一、背景 之前写了一篇文章 《小狗钱钱》 理财小白应该读的一本书,那时候我才看那本书,现在看了一大半了,发现这本书确实不错,...

tiankonguse
33分钟前
0
0
Permissions 0777 for ‘***’ are too open

异常显示: @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ WARNING: UNPROTECTED PRIVATE KEY FILE! @ @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ......

李玉长
35分钟前
0
0
区块链10年了,还未落地,它失败了吗?

导读 几乎每个人,甚至是对通证持怀疑态度的人,都对区块链的技术有积极的看法,因为它有可能改变世界。然而,区块链技术问世已经10年了,我们仍然没有真正的用上区块链技术。 几乎每个人,甚...

问题终结者
今天
2
0
20180921 su与sudo命令、限制root用户通过ssh远程登录

su 命令 用户切换。 su # 切换到root用户su username # 切换到username用户# su 后面加-时,会初始化当前用户的各种环境su - username # 指定用户执行某些命令 su - -c "touch /tm...

野雪球
今天
2
0
Windows 下双 Python 开发环境配置

Windows 下双 Python 开发环境配置作者:老农民(刘启华)QQ: 46715422Email: 46715422@qq.com微信: 46715422 本人曾经在 Windows 下被两个版本环境折腾够呛,现在总结两个 Python...

新疆老农民
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部