域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

存储过程

本章我们将讨论存储过程。

上一章我们学习了使用创建自定义函数。函数最大的缺点是,无法执行事务。存储过程解决了这个问题。

创建存储过程

使用 CREATE PROCEDURE 语句创建存储过程,语法如下:

  • 存储过程的参数模式只能是 ININOUT,而不能是OUT
  • 存储过程不能返回值
    • 即不能使用 RETURN 表达式;
    • 但可以使用不带表达式的 RETURN; 来停止存储过程
    • 如要从存储过程中返回值,可以使用 INOUT 模式的参数
  • 即不能使用 RETURN 表达式;
  • 但可以使用不带表达式的 RETURN; 来停止存储过程
  • 如要从存储过程中返回值,可以使用 INOUT 模式的参数

示例数据:

drop table if exists accounts;

create table accounts (
    id int generated by default as identity,
    name varchar(100) not null,
    balance dec(15,2) not null,
    primary key(id)
);

insert into accounts(name,balance)
values('Bob',10000);

insert into accounts(name,balance)
values('Alice',10000);

以下示例用于将指定金额从一个账户转账到另一个账户:

create or replace procedure transfer(
   sender int,
   receiver int, 
   amount dec
)
language plpgsql    
as $$
begin
    -- 从转账人账户里扣除金额
    update accounts 
    set balance = balance - amount 
    where id = sender;

    -- 给收款人账号增加金额
    update accounts 
    set balance = balance + amount 
    where id = receiver;

    commit;
end $$;
call transfer(1,2,1000);

删除存储过程

要查看完整内容,请先登录