欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 幼教 > Oracle:什么是存储过程

Oracle:什么是存储过程

2025/2/25 13:09:53 来源:https://blog.csdn.net/weixin_51020083/article/details/145822035  浏览:    关键词: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
BEGININSERT 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; 语句来调用它:

BEGINstudent_batch_insert;
END;
/

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

CREATE OR REPLACE PROCEDURE student_batch_insert(v_id NUMBER, v_name VARCHAR2, v_age NUMBER
)
AS
BEGININSERT INTO students (id, name, age) VALUES (v_id, v_name, v_age);COMMIT;
END;
/

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

BEGINstudent_batch_insert(4, 'David', 23);
END;
/

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com