0

0

实例讲解如何在 Oracle 中创建和执行存储过程

PHPz

PHPz

发布时间:2023-04-25 15:55:37

|

7149人浏览过

|

来源于php中文网

原创

oracle 是一个非常强大的数据库管理系统,它拥有很多高级的功能和特性,其中存储过程是其中之一。存储过程是一组针对数据库操作的预定义的 sql 语句,它可以存储在数据库中,供以后调用使用。

在 Oracle 中,存储过程用 PL/SQL 语言编写,它是一种结合了 SQL 和程序设计的语言。PL/SQL 具有很强的数据操作能力和过程控制能力,可以方便地编写出高效的存储过程来。

存储过程的好处

存储过程的主要好处是可以增加数据库的执行效率,减少网络通信的开销。因为存储过程已经被预先编译和优化,所以在执行时不需要反复进行解析和优化,可以直接调用执行。此外,存储过程还可以通过参数来实现动态化的操作,不仅可以简化代码,还可以避免 SQL 注入等风险。

存储过程的创建和执行

下面介绍一下如何在 Oracle 中创建和执行存储过程。

创建存储过程

在 Oracle 中,创建存储过程需要使用 CREATE PROCEDURE 语句,语法如下:

CREATE [OR REPLACE] PROCEDURE procedure_name
[(parameter_name [IN | OUT | IN OUT] parameter_type [, ...])]
[IS | AS]
BEGIN
      pl/sql_code_block;
END [procedure_name];

其中:

  • CREATE PROCEDURE:创建存储过程的语句。
  • OR REPLACE:可选参数,如果指定了该参数,则表示创建的存储过程已存在时,将其替换。
  • procedure_name:存储过程的名称。
  • parameter_name:可选的输入和/或输出参数,用于指定存储过程的输入和输出。
  • parameter_type:参数的类型,可以是数据类型如 VARCHAR2、NUMBER,也可以是游标类型,如 SYS_REFCURSOR。
  • IS | AS:可选参数,用于指定存储过程的语言类型,IS 表示开始(PL/SQL 块),AS 表示结束(PL/SQL 块)。
  • pl/sql_code_block:PL/SQL 代码块,它包含了存储过程的具体逻辑实现。

下面示例代码演示了如何创建一个简单的存储过程,它接受两个参数并输出它们的和:

CREATE OR REPLACE PROCEDURE add_nums(
    num1 IN NUMBER,
    num2 IN NUMBER,
    sum OUT NUMBER
)
IS
BEGIN
    sum := num1 + num2;
END add_nums;

执行存储过程

在 Oracle 中,执行存储过程需要使用 EXECUTE 或 EXECUTE IMMEDIATE 语句。例如,执行上述示例程序,可以使用如下的语句:

DECLARE
    result NUMBER;
BEGIN
    add_nums(10, 20, result);
    DBMS_OUTPUT.PUT_LINE('The sum is: ' || result);
END;

这里我们使用 DECLARE 语句来声明需要使用的变量 result,并调用 add_nums 存储过程,并将结果输出到屏幕上。

参数类型

在存储过程中,参数可以是输入参数、输出参数或双向参数。

  • 输入参数:指定存储过程的输入。
  • 输出参数:指定存储过程的输出。
  • 双向参数:既可以进行输入,也可以进行输出。

声明参数类型的方法如下:

(param_name [IN | OUT | IN OUT] param_type [, ...])

在这个声明中,[IN | OUT | IN OUT] 是可选的参数,用于指定参数的类型。如果不指定参数类型,则默认为 IN 类型,即输入参数。

PHP Apache和MySQL 网页开发初步
PHP Apache和MySQL 网页开发初步

本书全面介绍PHP脚本语言和MySOL数据库这两种目前最流行的开源软件,主要包括PHP和MySQL基本概念、PHP扩展与应用库、日期和时间功能、PHP数据对象扩展、PHP的mysqli扩展、MySQL 5的存储例程、解发器和视图等。本书帮助读者学习PHP编程语言和MySQL数据库服务器的最佳实践,了解如何创建数据库驱动的动态Web应用程序。

下载

示例代码:

CREATE OR REPLACE PROCEDURE my_proc (
    num IN NUMBER,
    str IN OUT VARCHAR2,
    cur OUT SYS_REFCURSOR
)
IS
BEGIN
    -- 逻辑实现
END my_proc;

在以上代码中,我们声明了一个包含三个参数的存储过程 my_proc,第一个参数 num 是输入参数,第二个参数 str 是双向参数,第三个参数 cur 是输出参数。

纪录集处理

用存储过程来操作数据时常常需要返回查询结果列表。Oracle 提供了两种类型的纪录集:游标和 PL/SQL 表。

游标

游标是一种返回结果集的数据结构,它可以遍历查询结果。游标可以是显式或隐式的,显式游标需要声明一个游标变量,并在代码中打开和关闭它,隐式游标则由 Oracle 自动创建和管理。

下面是一个演示如何使用游标的存储过程:

CREATE OR REPLACE PROCEDURE get_employee(
    id_list IN VARCHAR2,
    emp_cur OUT SYS_REFCURSOR
)
IS
BEGIN
    OPEN emp_cur FOR 'SELECT * FROM employees WHERE id IN (' || id_list || ')';
END get_employee;

在这个例子中,我们声明了一个包含两个参数的存储过程 get_employee,它接受一个以逗号分隔的员工 ID 列表作为输入参数,返回一个包含所选员工信息的游标 emp_cur。

PL/SQL 表

PL/SQL 表是一种类似于数组的数据结构,它可以存储一组值。PL/SQL 表在存储过程中有很多实际应用,例如将一组数据传递给存储过程等。

在 Oracle 中,可以在存储过程中声明和使用 PL/SQL 表,例如以下代码:

CREATE OR REPLACE PACKAGE my_package
IS
    TYPE num_list IS TABLE OF NUMBER INDEX BY PLS_INTEGER;

    PROCEDURE sum_nums(nums IN num_list, sum OUT NUMBER);
END my_package;

CREATE OR REPLACE PACKAGE BODY my_package
IS
    PROCEDURE sum_nums(nums IN num_list, sum OUT NUMBER)
    IS
        total NUMBER := 0;
    BEGIN
        FOR indx IN 1 .. nums.COUNT LOOP
            total := total + nums(indx);
        END LOOP;
        sum := total;
    END sum_nums;
END my_package;

在这里,我们创建了一个名为 my_package 的包,其中声明了一个名为 num_list 的 PL/SQL 表类型和一个使用该类型的存储过程 sum_nums。sum_nums 接受一个 num_list 类型的参数,并计算它们的总和。

结论

在 Oracle 中,存储过程是一种重要的维护数据库的工具之一,它具有高效的执行能力和动态性。我们也可以通过存储过程让其执行一些业务逻辑,而不是只执行单个的 SQL 语句,如此一来能够提高可重复使用性和可维护性。因为它们可以被存储在数据库中,并能够被多个应用程序或进程共享和访问。使用存储过程的好处很多,仅靠短短的文章很难覆盖它们的全部,但是我们相信,只要深入了解和应用,就会在实际工作中获益匪浅。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

17

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

61

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

19

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

158

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

164

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号