搜索
首页数据库mysql教程Oracle存储过程开发实例

在笔者的一个银行项目中,我接到编写Oracle存储过程的任务,我是程序员,脑袋里只有一些如何使用CALLABLE接口调用存储过程的经验

在笔者的一个银行项目中,我接到编写Oracle存储过程的任务,我是程序员,脑袋里只有一些如何使用CALLABLE接口调用存储过程的经验,一时不知如何下手,我查阅了一些资料,通过实践发现编写ORACLE存储过程是非常不容易的工作,即使上路以后,调试和验证非常麻烦。简单地讲,Oracle存储过程就是存储在Oracle数据库中的一个程序。

一.概述

Oracle存储过程开发的要点是:

◆使用Notepad文本编辑器,用OraclePL/SQL编程语言写一个存储过程;

◆在Oracle数据库中创建一个存储过程;

◆在Oracle数据库中使用SQL*Plus工具运行存储过程;

◆在Oracle数据库中修改存储过程;

◆通过编译错误调试存储过程;

◆删除存储过程;

二.环境配置

包括以下内容:

◆一个文本编辑器Notepad;

◆OracleSQL*Plus工具,提交OracleSQL和PL/SQL语句到Oracledatabase。

◆Oracle10gexpress数据库,它是免费使用的版本;

需要的技巧:

◆SQL基础知识,包括插入、修改、删除等

◆使用Oracle'sSQL*Plus工具的基本技巧;

◆使用Oracle'sPL/SQL编程语言的基本技巧;

三.写一个存储过程

存储过程使用Oracle'sPL/SQL程序语言编写,让我们写一个什么工作都不做的存储过程,我们可以编译和运行它而不用担心会对数据库产生任何损害。

在Notepad,写下:

CREATEORREPLACEPROCEDUREskeleton
IS

BEGIN

NULL;

END;

把文件存为skeleton.sql.
让我们一行行遍历这个存储过程:

1CREATEORREPLACEPROCEDUREskeleton
2IS

3BEGIN

4NULL;

5END;

行1:

CREATEORREPLACEPROCEDURE是一个SQL语句通知Oracle数据库去创建一个叫做skeleton存储过程,如果存在就覆盖它;

行2:

IS关键词表明后面将跟随一个PL/SQL体。

行3:

BEGIN关键词表明PL/SQL体的开始。

行4:

NULLPL/SQL语句表明什么事都不做,这句不能删去,因为PL/SQL体中至少需要有一句;

行5:

END关键词表明PL/SQL体的结束

四.创建一个存储过程

SQL语句CREATEORREPLACEPROCEDURE在Oracle数据库中创建、编译和保存一个存储过程。

从Window打开SQL*Plus并且从SQL*Plus登录到你的数据库;打开skeleton.sql文件.

在SQL>命令提示符下输入以下命令:

SQL>@skeleton

SQL>/

SQL*Plus装载skeleton.sql文件的内容到SQL*Plus缓冲区并且执行SQL*Plus语句;SQL*Plus会通知你存储过程已经被成功地创建。

现在你的存储过程被创建,编译和保存在你的Oracle数据库,我们可以运行它。

五.运行一个存储过程

从SQL*Plus命令行提示符运行你的存储过程使用EXECUTE命令,如下:

SQL>EXECUTEskeleton;

SQL*Plus输出一下信息确信存储过程成功执行:PL/SQLproceduresuccessfullycompleted.

你也可以在一个无名PL/SQL块内运行你的存储过程,在SQL*Plus命令提示符下,它看起来像:

SQL>BEGIN

2SKELETON;

3END;

4/

现在我们已经运行了我们的存储过程,我们如何修改它呢?

六.修改一个存储过程

让我们写一个输出字符串“HelloWorld!”的存储过程,用Notepad打开你的skeleton.sql文件,.用DBMS_OUTPUT.PUT_LINE过程调用去替换NULL语句,如下所示:

CREATEORREPLACEPROCEDUREskeleton
IS

BEGIN

DBMS_OUTPUT.PUT_LINE('HelloWorld!');

END;

保存到文件skeleton.sql.

从SQL*Plus命令行,打开文件skeleton.sql.

SQL>@skeleton
SQL>

1CREATEORREPLACEPROCEDUREskeleton

2IS

3BEGIN

4DBMS_OUTPUT.PUT_LINE('HelloWorld!');

5*END;

SQL>/

SQL*Plus通知你存储过程成功创建并输出提示信息:Procedurecreated.

SQL>

用EXECUTE命令运行你的存储过程:

SQL>EXECUTEskeleton;

SQL*Plus显示存储过程运行成功:PL/SQLproceduresuccessfullycompleted.

我们想要的输出字符串"HelloWorld!"没有出来,在显示一个DBMS_OUTPUT.PUT_LINE结果前需要运行一个SET命令,在SQL*Plus命令行提示符,键入:

SQL>SETSERVEROUTPUTON

再次执行你的存储过程:

SQL>EXECUTEskeleton;

现在结果输出了:HelloWorld!

PL/SQLproceduresuccessfullycompleted.

七.调试一个存储过程

当调试一个存储过程时,遵循一样的步骤,修改SQL文件,创建存储过程,执行存储过程,根据编译器反馈的出错信息进行修改,这一步是非常繁琐的,需要依靠经验。

在实际的商用存储过程的开发调试过程中,由于涉及很多表、类型、光标、循环、条件等复杂的逻辑,和PL/SQL语句的灵活运用,编译时会产生很多错误提示信息,程序员在根据这些错误信息定位,进行修正,再编译最后得到正确的结构;

八.放弃一个存储过程

如果在数据库中你不在需要一个存储过程你可以删除它,,SQL语句DROPPROCEDURE完成从数据库中删除一个存储过程,DROPPROCEDURE在SQL中被归类为数据定义语言(DDL)类操作,其他的例子有CREATE,ALTER,RENAME和TRUNCATE。.

在SQL*Plus命令提示符下,使用DROPPROCEDURESQL语句删除你的叫做skeleton的存储过程:

SQL>DROPPROCEDUREskeleton;
SQL*Plusassuresustheprocedurehasbeenremoved:

Proceduredropped.

总结

本文详细讨论了如何使用Oracle工具开发Oracle商用存储过程的步骤。最后在存储过程的使用中可能是程序直接调用,也可能被触发器调用。

linux

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
您什么时候应该使用复合索引与多个单列索引?您什么时候应该使用复合索引与多个单列索引?Apr 11, 2025 am 12:06 AM

在数据库优化中,应根据查询需求选择索引策略:1.当查询涉及多个列且条件顺序固定时,使用复合索引;2.当查询涉及多个列但条件顺序不固定时,使用多个单列索引。复合索引适用于优化多列查询,单列索引则适合单列查询。

如何识别和优化MySQL中的慢速查询? (慢查询日志,performance_schema)如何识别和优化MySQL中的慢速查询? (慢查询日志,performance_schema)Apr 10, 2025 am 09:36 AM

要优化MySQL慢查询,需使用slowquerylog和performance_schema:1.启用slowquerylog并设置阈值,记录慢查询;2.利用performance_schema分析查询执行细节,找出性能瓶颈并优化。

MySQL和SQL:开发人员的基本技能MySQL和SQL:开发人员的基本技能Apr 10, 2025 am 09:30 AM

MySQL和SQL是开发者必备技能。1.MySQL是开源的关系型数据库管理系统,SQL是用于管理和操作数据库的标准语言。2.MySQL通过高效的数据存储和检索功能支持多种存储引擎,SQL通过简单语句完成复杂数据操作。3.使用示例包括基本查询和高级查询,如按条件过滤和排序。4.常见错误包括语法错误和性能问题,可通过检查SQL语句和使用EXPLAIN命令优化。5.性能优化技巧包括使用索引、避免全表扫描、优化JOIN操作和提升代码可读性。

描述MySQL异步主奴隶复制过程。描述MySQL异步主奴隶复制过程。Apr 10, 2025 am 09:30 AM

MySQL异步主从复制通过binlog实现数据同步,提升读性能和高可用性。1)主服务器记录变更到binlog;2)从服务器通过I/O线程读取binlog;3)从服务器的SQL线程应用binlog同步数据。

mysql:简单的概念,用于轻松学习mysql:简单的概念,用于轻松学习Apr 10, 2025 am 09:29 AM

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

MySQL:数据库的用户友好介绍MySQL:数据库的用户友好介绍Apr 10, 2025 am 09:27 AM

MySQL的安装和基本操作包括:1.下载并安装MySQL,设置根用户密码;2.使用SQL命令创建数据库和表,如CREATEDATABASE和CREATETABLE;3.执行CRUD操作,使用INSERT,SELECT,UPDATE,DELETE命令;4.创建索引和存储过程以优化性能和实现复杂逻辑。通过这些步骤,你可以从零开始构建和管理MySQL数据库。

InnoDB缓冲池如何工作,为什么对性能至关重要?InnoDB缓冲池如何工作,为什么对性能至关重要?Apr 09, 2025 am 12:12 AM

InnoDBBufferPool通过将数据和索引页加载到内存中来提升MySQL数据库的性能。1)数据页加载到BufferPool中,减少磁盘I/O。2)脏页被标记并定期刷新到磁盘。3)LRU算法管理数据页淘汰。4)预读机制提前加载可能需要的数据页。

MySQL:初学者的数据管理易用性MySQL:初学者的数据管理易用性Apr 09, 2025 am 12:07 AM

MySQL适合初学者使用,因为它安装简单、功能强大且易于管理数据。1.安装和配置简单,适用于多种操作系统。2.支持基本操作如创建数据库和表、插入、查询、更新和删除数据。3.提供高级功能如JOIN操作和子查询。4.可以通过索引、查询优化和分表分区来提升性能。5.支持备份、恢复和安全措施,确保数据的安全和一致性。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用