COBOL-DB2 程序如何调用存储过程?请举例说明。


存储过程通常包含一个或多个程序中经常使用的 SQL 语句。存储过程的主要优点是减少了 COBOL 和 DB2 之间的数据流量,因为存储过程驻留在 DB2 中。

COBOL-DB2 程序可以使用 CALL 语句调用存储过程,并且我们可以嵌套存储过程最多 16 层。例如,如果我们有一个名为 ORDERSTAT 的存储过程,那么我们可以使用以下命令在我们的 COBOL-DB2 程序中调用它

示例

EXEC SQL
   CALL ORDERSTAT (:WS-ORDER-ID, :WS-ORDER-STATUS)
END-EXEC

为了创建 DB2 过程,我们可以给出如下定义。

示例

CREATE PROCEDURE ORDERSTAT ( IN ORDER-ID int,
OUT ORDER-STAT char)

我们可以如下定义存储过程。

示例

LANGUAGE SQL
PROCA: BEGIN
DECLARE ORDERID int;
SELECT ORDER_STAT FROM ORDERS
   WHERE ORDER_ID = ORDERID;
END P1

以下是使用存储过程的一些优点。

  • 核心逻辑和算法集中存储在 DB2 中,并由数据库管理系统管理。这有助于可重用性,并且只需在一个中央位置进行修改即可节省精力。
  • 可以根据为 DB2 中的不同配置文件设置的权限来限制对存储过程的访问。
  • 逻辑在数据库服务器上执行,这减少了 DB2 网络上的流量,从而减少了整体执行时间。

更新于: 2020-12-01

4K+ 浏览量

启动您的 职业生涯

通过完成课程获得认证

开始学习
广告