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

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; 用于 执行存储过程

相关文章:

  • 【利用conda配置管理Python版本和依赖环境】
  • 【Java项目】基于Spring Boot的教师人事档案管理系统
  • AIoT是什么?关键技术及应用
  • C++ Primer 初识泛型算法
  • 服务器离线部署DeepSeek
  • 电脑连接示波器显示波形
  • 在 HuggingFace 中使用 SSH 进行下载数据集和模型
  • git 查询包含某个文件夹的步骤
  • 快节奏生活
  • 关于vue中el-date-picker type=daterange日期不回显的问题
  • 电子商务网站租用香港服务器的好处有哪些?
  • Vue04
  • (网络安全)如何建立安全运营中心
  • 本地大模型编程实战(23)用智能体(Agent)实现基于SQL数据构建问答系统(2)
  • 【Java项目】基于Spring Boot的火车订票管理系统
  • sage-huga改进SITAN
  • 简单介绍 SSL 证书类型: DV、OV、EV 的区别
  • 【Mastering Vim 2_07】第六章:正则表达式和 Vim 宏在代码重构中的实战应用
  • SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)
  • ResNet 改进:添加LSKBlock动态调整其大空间感受场
  • 商务部就美国商务部调整芯片出口管制有关表述答记者问
  • 国家统计局:消费对我国经济增长的拉动有望持续增长
  • 假冒政府机构账号卖假货?“假官号”为何屡禁不绝?媒体调查
  • 上海青少年书法学习园开园:少年以巨笔书写《祖国万岁》
  • 孟夏韵评《无序的学科》丨误读与重构的文化漂流
  • 海昏侯博物馆展览上新,“西汉帝陵文化展”将持续展出3个月