暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

华为GaussDB T 执行存储过程

墨天轮 2019-10-12
497

执行存储过程

功能描述

执行存储过程。

注意事项

  • 自定义存储过程和系统函数重名时,数据库会优先调用系统函数。如果需要优先调用重名的自定义存储过程,则需要将该自定义存储过程配置在$GSDB_DATA/cfg/udf.ini中,格式为user_name.procedure_name,配置完成后,需要重启数据库,配置才会生效。
  • udf.ini文件的权限应设置为只有数据库用户组dbgrp中的用户有权限修改,权限为600。
  • 执行存储过程时,可以指定参数列表中所有参数的值,也可以使用“=>”指定部分参数的值。指定部分参数值时,如果存在既没有缺省值也没有指定值的参数会报错。
  • 执行存储过程时,不允许使用常量对IN OUT类型和OUT类型的输入参数赋值。
  • 执行存储过程时,建议用户发现行号报错的时候查看SYS_PROCS视图来对应行号。
  • 执行不带参数的存储过程(包括自定义函数),可以直接给定存储过程名或自定义函数名,不需要带括号。
  • 执行存储过程时,可以用分号“;”作为结束符,或者直接换行使用“/”作为结束符;但不能两个结束符一起使用,如果一起使用会报错。

语法格式

{ CALL | EXEC } [schema_name.]procedure_name[(param[,...])];

参数说明

  • CALL

    执行存储过程指令。

  • EXEC

    执行存储过程指令。

  • schema_name

    存储过程所有者。

  • procedure_name

    存储过程名称。

  • param

    存储过程参数,如果编译的存储过程不带参数,执行时可以不加括号。

示例

  • 使用不带参数的存储过程。
    --为存储过程案例准备基础表。 --删除重名的临时表。 DROP TABLE IF EXISTS table_temp; --创建临时表。 CREATE TABLE table_temp(f1 INT, f2 VARCHAR2(20));

    存储过程和函数存储在同一个系统表中,如果新创建的存储过程和已有自定义函数重名,将导致创建存储过程失败。因此,在创建存储过程之前,需要删除重名的自定义函数。

    --删除重名的自定义函数。 DROP FUNCTION IF EXISTS p_no_param;
    --删除重名的存储过程。 DROP PROCEDURE IF EXISTS p_no_param;

    创建存储过程时,最后的“/”符号用于标示存储过程定义语句的结束,不能省略,且必须单独成行。

    --创建一个不带参数的存储过程。 CREATE OR REPLACE PROCEDURE p_no_param IS BEGIN INSERT INTO table_temp VALUES(1,'xxx'); COMMIT; END; /
    --使用CALL执行存储过程。 CALL p_no_param; --使用EXEC执行存储过程。 EXEC p_no_param;
    --检查临时表数据。 SELECT * FROM table_temp; F1 F2 ------------ -------------------- 1 xxx 1 xxx 2 rows fetched.
    --删除存储过程。 DROP PROCEDURE p_no_param;
  • 使用带IN模式参数的存储过程。
    --为存储过程案例准备基础表。 --删除重名的临时表。 DROP TABLE IF EXISTS table_temp; --创建临时表。 CREATE TABLE table_temp(f1 INT, f2 INT, f3 VARCHAR2(20));

    存储过程和函数存储在同一个系统表中,如果新创建的存储过程和已有自定义函数重名,将导致创建存储过程失败。因此,在创建存储过程之前,需要删除重名的自定义函数。

    --删除重名的自定义函数。 DROP FUNCTION IF EXISTS p_with_param;
    --删除重名的存储过程 DROP PROCEDURE IF EXISTS p_with_param;

    创建存储过程时,最后的“/”符号用于标示存储过程定义语句的结束,不能省略,且必须单独成行。

    --创建存储过程,第一个参数和第二个参数均有默认值0,第三个参数没有默认值。 CREATE OR REPLACE PROCEDURE p_with_param(param1 INT := 0, param2 INT DEFAULT 0,param3 VARCHAR2) IS BEGIN INSERT INTO table_temp VALUES(param1,param2,param3); COMMIT; END; /
    --执行存储过程时指定全部输入参数的值。 --使用CALL执行存储过程。 CALL p_with_param(1,1,'xxx'); --使用EXEC执行存储过程。 EXEC p_with_param(1,1,'xxxx');

    指定部分参数的值时,需要为所有没有默认值的参数指定值。如果一个参数既没有默认值,也没有指定值,则会返回错误。

    --执行存储过程时,只为没有默认值的参数指定值。 --使用CALL执行存储过程。 CALL p_with_param(param3=>'yyy'); --使用EXEC执行存储过程。 EXEC p_with_param(param3=>'yyyy');
    --查询临时表数据。 SELECT * FROM table_temp; F1 F2 F3 ------------ ------------ -------------------- 1 1 xxx 1 1 xxxx 0 0 yyy 0 0 yyyy 4 rows fetched.
    --删除存储过程。 DROP PROCEDURE p_with_param;

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论