openGauss学习笔记-44 openGauss 高级数据管理-存储过程

文章目录

    • [openGauss学习笔记-44 openGauss 高级数据管理-存储过程](#openGauss学习笔记-44 openGauss 高级数据管理-存储过程)
      • [44.1 语法格式](#44.1 语法格式)
      • [44.2 参数说明](#44.2 参数说明)
      • [44.3 示例](#44.3 示例)

openGauss学习笔记-44 openGauss 高级数据管理-存储过程

存储过程是能够完成特定功能的SQL语句集。用户可以进行反复调用,从而减少SQL语句的重复编写数量,提高工作效率。

44.1 语法格式

  • 创建存储过程

    sql 复制代码
    CREATE PROCEDURE procedure_name
        [ ( {[ argname ] [ argmode ] argtype [ = expression ]}[,...]) ]
        { IS | AS } 
        BRGIN
          procedure_body
        END
    /
  • 调用存储过程

    sql 复制代码
    CALL procedure_name ( param_expr );
  • 删除存储过程

    sql 复制代码
    DROP PROCEDURE procedure_name ;

44.2 参数说明

  • procedure_name

    创建的存储过程名称。

  • argname

    参数的名称。

  • argmode

    参数的模式。取值范围: IN,OUT,INOUT或VARIADIC。VARIADIC用于声明数组类型的参数。缺省值是IN。

    • IN

      输入参数。表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回。

    • OUT

      输出参数。该值可在存储过程内部被改变,并可返回。

    • INOUT

      输入输出参数。调用时指定,并且可被改变和返回。

  • argtype

    参数的数据类型。

  • expression

    设定缺省值。

  • IS、AS

    语法格式要求,必须写其中一个。两个相同。

  • BRGIN、END

    语法格式要求,必须写。

  • procedure_body

    存储过程内容。

  • param_expr

    参数列表。参数间用符号","隔开;参数名和参数值用符号 ":="或者"=>"隔开。

44.3 示例

bash 复制代码
--创建表格
openGauss=# CREATE TABLE graderecord  
(  
  number INTEGER,  
  name CHAR(20),  
  class CHAR(20),  
  grade INTEGER
);

--定义存储过程
openGauss=# CREATE PROCEDURE insert_data  (param1 INT = 0, param2 CHAR(20),param3 CHAR(20),param4 INT = 0 ) 
IS
 BEGIN 
 INSERT INTO graderecord VALUES(param1,param2,param3,param4);  
END;
/

--调用存储过程
openGauss=# CALL insert_data(param1:=210101,param2:='Alan',param3:='21.01',param4:=92);

--删除存储过程
openGauss=# DROP PROCEDURE insert_data;

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

相关推荐
泊浮目6 分钟前
未来数据库硬件-网络篇
数据库·架构·云计算
静若繁花_jingjing20 分钟前
Redis线程模型
java·数据库·redis
翻滚吧键盘30 分钟前
debian及衍生发行版apt包管理常见操作
运维·debian
Charlene Fung1 小时前
vs code远程自动登录服务器,无需手动输入密码的终极方案(windows版)
运维·服务器·vscode·ssh
碣石潇湘无限路2 小时前
【部署与总结】从本地运行到公网服务器的全过程
运维·服务器
飞翔的佩奇2 小时前
Java项目:基于SSM框架实现的忘忧小区物业管理系统【ssm+B/S架构+源码+数据库+毕业论文+开题报告】
java·数据库·mysql·vue·毕业设计·ssm框架·小区物业管理系统
linux修理工2 小时前
ipmitool 使用简介(ipmitool sel list & ipmitool sensor list)
运维·服务器
XM-54582 小时前
2025微信小程序wxapkg解包全攻略
linux·运维·小程序
朗晴3 小时前
文本编辑器VIM的使用方法!
linux·运维·服务器
小林up3 小时前
github push:ssh: connect to host github.com port 22
运维·ssh·github