在 Oracle 里,存储过程(Procedure)是 一组 SQL 语句的封装,可以在数据库中保存,并在需要时直接调用,避免重复编写 SQL 代码。
存储过程的主要作用:
- 批量操作(如批量插入、批量更新)
- 封装业务逻辑
- 提高 SQL 复用性
- 减少数据库与应用程序的交互次数,提高性能
假设我们有一个 students
表:
CREATE TABLE students (
id NUMBER PRIMARY KEY,
name VARCHAR2(50),
age NUMBER
);
现在要创建一个存储过程:
- 插入多条学生数据
- 每次执行都会插入固定的 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;
用于 执行存储过程。