Oracle:什么是存储过程

Oracle 里,存储过程(Procedure)是 一组 SQL 语句的封装,可以在数据库中保存,并在需要时直接调用,避免重复编写 SQL 代码。

存储过程的主要作用:

  • 批量操作(如批量插入、批量更新)
  • 封装业务逻辑
  • 提高 SQL 复用性
  • 减少数据库与应用程序的交互次数,提高性能

假设我们有一个 students 表:

复制代码
CREATE TABLE students (
    id NUMBER PRIMARY KEY,
    name VARCHAR2(50),
    age NUMBER
);

现在要创建一个存储过程

  1. 插入多条学生数据
  2. 每次执行都会插入固定的 3 条记录
  3. 提交(COMMIT)保证数据写入数据库
sql 复制代码
CREATE OR REPLACE PROCEDURE student_batch_insert
AS
BEGIN
    INSERT INTO students (id, name, age) VALUES (1, 'Alice', 20);
    INSERT INTO students (id, name, age) VALUES (2, 'Bob', 22);
    INSERT INTO students (id, name, age) VALUES (3, 'Charlie', 21);
    COMMIT; -- 提交事务,确保数据永久存储
END;
/

如何运行这个过程?

创建存储过程后,可以用 BEGIN ... END; 语句来调用它:

sql 复制代码
BEGIN
    student_batch_insert;
END;
/

上面的存储过程每次执行都会插入固定的数据 ,但如果我们希望传入不同的数据 ,可以使用参数

sql 复制代码
CREATE OR REPLACE PROCEDURE student_batch_insert(
    v_id NUMBER, 
    v_name VARCHAR2, 
    v_age NUMBER
)
AS
BEGIN
    INSERT INTO students (id, name, age) VALUES (v_id, v_name, v_age);
    COMMIT;
END;
/

这样,执行时可以传入不同的数据

sql 复制代码
BEGIN
    student_batch_insert(4, 'David', 23);
END;
/

存储过程 就是 数据库端的函数,用于封装 SQL 逻辑,避免重复编写 SQL 代码。

CREATE OR REPLACE PROCEDURE 用于 创建或更新存储过程 ,而 BEGIN ... END; 用于 执行存储过程

相关推荐
小猿姐3 小时前
实测对比:哪款开源 Kubernetes MySQL Operator 最值得用?(2026 深度评测)
数据库·mysql·云原生
倔强的石头_5 小时前
从 “存得下” 到 “算得快”:工业物联网需要新一代时序数据平台
数据库
TDengine (老段)6 小时前
TDengine IDMP 可视化 —— 分享
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据·时序数据
GottdesKrieges7 小时前
OceanBase数据库备份配置
数据库·oceanbase
SPC的存折8 小时前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql
运维行者_8 小时前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发
炸炸鱼.9 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
softshow10269 小时前
Etsy 把 1000 个 MySQL 分片迁进 Vitess
数据库·mysql
Ronaldinho Gaúch9 小时前
MySQL基础
数据库·mysql
不剪发的Tony老师10 小时前
Noir:一款键盘驱动的现代化数据库管理工具
数据库·sql