0

0

postgresql存储过程如何编写_postgresqlplpgsql开发指南

舞夢輝影

舞夢輝影

发布时间:2025-11-27 22:11:01

|

736人浏览过

|

来源于php中文网

原创

PostgreSQL从11开始支持存储过程,使用PL/pgSQL编写,可通过CALL调用,支持事务控制与复杂逻辑处理。

postgresql存储过程如何编写_postgresqlplpgsql开发指南

PostgreSQL 中的存储过程可以通过 PL/pgSQL 编写,这是一种功能强大的过程语言,允许你在数据库中定义复杂的逻辑。从 PostgreSQL 11 开始,正式支持使用 CREATE PROCEDURE 命令创建真正的存储过程(与函数不同,存储过程可以使用事务控制命令如 COMMIT 和 ROLLBACK)。

什么是 PL/pgSQL?

PL/pgSQL 是 PostgreSQL 的过程语言扩展,语法类似 Oracle 的 PL/SQL,支持变量定义、条件判断、循环、异常处理等结构化编程特性,非常适合编写复杂的数据操作逻辑。

基本语法:创建一个存储过程

使用 CREATE OR REPLACE PROCEDURE 来定义或修改存储过程:

CREATE OR REPLACE PROCEDURE insert_user(
    IN user_name TEXT,
    IN user_email TEXT
)
AS $$
BEGIN
    INSERT INTO users (name, email, created_at)
    VALUES (user_name, user_email, NOW());
END;
$$ LANGUAGE plpgsql;

说明:

  • IN 参数:表示输入参数,也可以省略 IN 关键字,默认就是输入参数。
  • LANGUAGE plpgsql:指定过程语言为 PL/pgSQL。
  • $$ ... $$:称为“美元引用”,用来包裹函数体,避免引号冲突。

调用存储过程

使用 CALL 命令来执行存储过程:

CALL insert_user('Alice', 'alice@example.com');

该语句会向 users 表插入一条记录。

带输出参数的存储过程

存储过程也可以返回值,通过 OUTINOUT 参数实现:

CREATE OR REPLACE PROCEDURE get_user_count(
    OUT total_count INTEGER
)
AS $$
BEGIN
    SELECT COUNT(*) INTO total_count FROM users;
END;
$$ LANGUAGE plpgsql;

调用方式:

腾讯交互翻译
腾讯交互翻译

腾讯AI Lab发布的一款AI辅助翻译产品

下载
CALL get_user_count(); -- 返回结果集中的 total_count

在存储过程中使用事务控制

这是存储过程区别于函数的重要特性 —— 可以在过程中提交或回滚事务(仅适用于 PostgreSQL 11+):

CREATE OR REPLACE PROCEDURE transfer_money(
    IN from_account INT,
    IN to_account INT,
    IN amount NUMERIC
)
AS $$
BEGIN
    UPDATE accounts SET balance = balance - amount WHERE id = from_account;
    IF NOT FOUND THEN
        RAISE EXCEPTION '源账户不存在';
    END IF;
<pre class='brush:php;toolbar:false;'>UPDATE accounts SET balance = balance + amount WHERE id = to_account;
IF NOT FOUND THEN
    RAISE EXCEPTION '目标账户不存在';
END IF;

COMMIT; -- 显式提交事务

EXCEPTION WHEN OTHERS THEN ROLLBACK; RAISE; END; $$ LANGUAGE plpgsql;

这个例子展示了如何在出错时回滚事务,确保数据一致性。

常见结构和控制语句

PL/pgSQL 支持多种流程控制结构:

IF 判断:
IF score > 90 THEN
    grade := 'A';
ELSIF score > 80 THEN
    grade := 'B';
ELSE
    grade := 'C';
END IF;

LOOP 循环:

DECLARE
    i INTEGER := 1;
BEGIN
    WHILE i <= 10 LOOP
        INSERT INTO numbers (value) VALUES (i);
        i := i + 1;
    END LOOP;
END;

遍历查询结果:

FOR rec IN SELECT name, email FROM users WHERE active THEN
    RAISE NOTICE '用户: %, 邮箱: %', rec.name, rec.email;
END LOOP;

错误处理(异常捕获)

使用 EXCEPTION 块捕获运行时错误:

BEGIN
    DELETE FROM users WHERE id = user_id;
EXCEPTION
    WHEN NO_DATA_FOUND THEN
        RAISE NOTICE '未找到用户 ID %', user_id;
    WHEN OTHERS THEN
        RAISE NOTICE '发生未知错误: %', SQLERRM;
END;

开发建议与注意事项

  • 尽量使用有意义的命名规范,如 proc_insert_order
  • 避免在存储过程中做大量计算或复杂业务逻辑,优先考虑应用层处理。
  • 调试可用 RAISE NOTICE 输出中间状态。
  • 注意权限问题,确保调用者有执行权限和涉及表的操作权限。
  • 版本兼容性:事务控制仅在 PostgreSQL 11 及以上版本的存储过程中可用。

基本上就这些。掌握这些基础后,你可以编写高效、安全的数据库级逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1134

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2174

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1703

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 4.3万人学习

Java 教程
Java 教程

共578课时 | 81.3万人学习

oracle知识库
oracle知识库

共0课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号