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

Oracle:什么是存储过程

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

存储过程的主要作用:

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

假设我们有一个 students 表:

CREATE TABLE students (
    id NUMBER PRIMARY KEY,
    name VARCHAR2(50),
    age NUMBER
);

现在要创建一个存储过程

  1. 插入多条学生数据
  2. 每次执行都会插入固定的 3 条记录
  3. 提交(COMMIT)保证数据写入数据库
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; 语句来调用它:

BEGIN
    student_batch_insert;
END;
/

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

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;
/

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

BEGIN
    student_batch_insert(4, 'David', 23);
END;
/

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

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


http://www.kler.cn/a/562686.html

相关文章:

  • USC安防平台之元数据检索
  • 创建第一个 Maven 项目(二)
  • Windows获取字体文件
  • 【Godot4.3】基于绘图函数的矢量蒙版效果与UV换算
  • 1.部署zookeeper集群:2181
  • Docker国内镜像源部署deepseek
  • jspssm542Springboot 医疗服务系统
  • 如何实现在Redis集群情况下,同一类数据固定保存在同一个Redis实例中
  • C语言预处理指令如#endif
  • TCP初始化序列号为什么要不一样
  • header在spring boot中解析
  • 工厂方法模式:思考与解读
  • 企业级大模型应用的Java-Python异构融合架构实践
  • 【机器学习】强化学习(2)——捋清深度强化学习的思路
  • 【数据结构初阶第十五节】堆的应用(堆排序 + Top-K问题)
  • 用AI写游戏3——用java实现坦克大战游戏1
  • docker下搭建redis集群
  • 九、数据治理架构流程
  • AI 百炼成神:逻辑回归, 垃圾邮件分类
  • Selenium 调用模型接口实现功能测试