当前位置: 首页 > news >正文

Postgresql中PL/pgSQL的游标、自定义函数、存储过程的使用

场景

Postgresql中PL/pgSQL代码块的语法与使用-声明与赋值、IF语句、CASE语句、循环语句:

Postgresql中PL/pgSQL代码块的语法与使用-声明与赋值、IF语句、CASE语句、循环语句-CSDN博客

上面讲了基本语法,下面记录游标、自定义函数、存储过程的使用。

注:

博客:
霸道流氓气质_C#,架构之路,SpringBoot-CSDN博客

实现

1、PL/pgSQL游标

PL/pgSQL 游标允许我们封装一个查询,然后每次处理结果集中的一条记录。游标可以将大结果集拆分成许多小的记录,

避免内存溢出;另外,我们可以定义一个返回游标引用的函数,然后调用程序可以基于这个引用处理返回的结果集。

使用游标的步骤:

1. 声明游标变量;

2. 打开游标;

3. 从游标中获取结果;

4. 判断是否存在更多结果。如果存在,执行第 3 步;否则,执行第 5 步;

5. 关闭游标。

示例代码:

DO $$
DECLARErec_user RECORD;cur_user CURSOR(user_name VARCHAR) FORSELECT id, nameFROM b_userWHERE name = user_name;
BEGIN-- 打开游标OPEN cur_user('222');LOOP-- 获取游标中的记录FETCH cur_user INTO rec_user;-- 没有找到更多数据时退出循环EXIT WHEN NOT FOUND;RAISE NOTICE '%,% ' , rec_user.id, rec_user.name;END LOOP;-- Close the cursorCLOSE cur_user;
END $$;

示例代码运行结果

首先,声明了一个游标 cur_user,并且绑定了一个查询语句,通过一个参数user_name 获取指定姓名的用户;

然后使用 OPEN 打开游标;接着在循环中使用 FETCH 语句获取游标中的记录,如果没有找到更多数据退出循环语句;

变量 rec_user 用于存储游标中的记录;最后使用 CLOSE语句关闭游标,释放资源。

2、创建自定义PL/pgSQL函数

要创建一个自定义的 PL/pgSQL 函数,可以使用 CREATE FUNCTION 语句。

CREATE 表示创建函数,OR REPLACE 表示替换函数定义;

name 是函数名;括号内是参数,多个参数使用逗号分隔;argmode 可以是 IN(输入)、OUT(输出)、INOUT(输入输出)

或者 VARIADIC(数量可变),默认为 IN;argname 是参数名称;argtype 是参数的类型;default_expr是参数的默认值;

rettype 是返回数据的类型;AS 后面是函数的定义,和上文中的匿名块相同;最后,LANGUAGE 指定函数实现的语言。

创建一个示例函数,用于返回指定姓名的用户数量

CREATEOR REPLACE FUNCTION get_user_count (user_name VARCHAR ) RETURNS INTEGER AS $$ DECLAREln_count INTEGER;
BEGINSELECT COUNT(*) INTO ln_countFROMb_userWHEREname = user_name;RETURN ln_count;END; $$ LANGUAGE plpgsql;

函数调用方式

SELECT name,get_user_count(name)
FROM b_user ;

调用结果

3、创建存储过程

存储过程,使用 CREATE PROCEDURE 语句创建

存储过程的定义和函数主要的区别在于没有返回值,其他内容都类似。以下示例创建了一个存储过程用于修改用户的信息

CREATEOR REPLACE PROCEDURE update_user (user_id in integer,user_name IN VARCHAR) AS $$ BEGINUPDATE b_userSET name = user_nameWHEREid = user_id;END; $$ LANGUAGE plpgsql;

存储过程调用方法:

call update_user(1,'badao');

http://www.lryc.cn/news/264513.html

相关文章:

  • 【IDEA】Intellij IDEA相关配置
  • GD32移植STM32工程(因为懒,所以移植)
  • mt5和mt4交易软件有什么区别?
  • 零刻EQ12 N100 双2.5G网口 All In One新手教程
  • 竞赛保研 基于Django与深度学习的股票预测系统
  • 听GPT 讲Rust源代码--src/tools(16)
  • Leetcoed 双指针
  • 关于“Python”的核心知识点整理大全31
  • 第1章 SpringBoot开发入门
  • 利用prometheus+grafana进行Linux主机监控
  • 单词反转(字符串)
  • 【Java 集合】LinkedBlockingDeque
  • 【hacker送书第3期】OpenCV轻松入门:面向Python(第2版)
  • 手把手教你isPalindrome 方法在密码验证中的应用
  • drf入门规范(二)
  • 使用Redis和Nginx分别实现限制接口请求频率
  • ansible模块 (7-13)
  • MySQL概括与SQL分类
  • 微信小程序:wx:for 获取view点击的元素currentTarget.dataset为空
  • Word的兼容性问题很常见,禁用兼容模式虽步不是最有效的,但可以解决兼容性问题
  • 环境搭建及源码运行_java环境搭建_idea版本下载及安装
  • jvm相关命令操作
  • 芋道前端框架上线之后发现element-ui的icon图标全部乱码
  • 每个伦敦金投资者都应该练习的日线图交易
  • 高通平台开发系列讲解(USB篇)adb应用adbd分析
  • 【上海大学数字逻辑实验报告】七、中规模元件及综合设计
  • JVM内存结构Java内存模型Java对象模型
  • Istio 社区周报(第一期):2023.12.11 - 12.17
  • 质量图导向法解包裹之---计算边缘可靠性
  • C# WPF上位机开发(进度条操作)