oracle数据库的存储过程是什么?


本文摘自PHP中文网,作者青灯夜游,侵删。

oracle数据库的存储过程:一组为了完成特定功能的SQL语句集,经编译后存储在数据库中。存储过程是由流控制和SQL语句书写的过程,这个过程经编译和优化后存储在数据库服务器中,应用程序使用时只要调用即可。

存储过程(Stored Procedure )是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。

存储过程是由流控制和SQL 语句书写的过程,这个过程经编译和优化后存储在数据库服务器中,应用程序使用时只要调用即可。在ORACLE 中,若干个有联系的过程可以组合在一起构成程序包。

优点:

1、存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。

2、当对数据库进行复杂操作时(如对多个表进行Update、Insert、Query、Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。

3、存储过程可以重复使用,可减少数据库开发人员的工作量。

4、安全性高,可设定只有某用户才具有对指定存储过程的使用权。

简单说,你在你的机器上写了个存储过程,这个存储过程像那些表里的数据一样被放在遥远的数据库服务器当中,但是它又是可执行的代码,其他能连到数据库服务器的用户,可以调用你写的存储过程

它的作用是隐藏细节,就是说,你写的存储过程代码可能很复杂,但是其他人调用它却很简单,不用具体知道它是如何做的,且一次能完成多个指令

基本语法

1

2

3

4

5

6

7

8

CREATE [OR REPLACE] PROCEDURE 存储过程名[(参数[IN|OUT|IN OUT] 数据类型...)]

{AS|IS}

[说明部分]

BEGIN

可执行部分

[EXCEPTION

错误处理部分]

END [过程名];

1、可选关键字OR REPLACE 表示如果存储过程已经存在,则用新的存储过程覆盖,通常用户存储过程的重建。

2、参数部分用于定义多个参数(如果没有参数,就可以省略)。参数有三种形式:IN、OUT和IN OUT。如果没有指明参数的形式,则默认为IN。

3、关键字AS也可以写成IS,后跟过程的说明部分,可以在此定义过程的局部变量。

4、编写存储过程可以使用任何文本编辑器或直接在SQLPLus环境下进行,编写好的存储过程必须要在SQLPLus环境下进行编译,生成编译代码,原代码和编译代码在编译过程中都会被存入数据库。编译成功的存储过程就可以在ORacle环境下进行调用了。

5、一个存储过程在不需要时可以删除。删除存储过程的人是过程的创建者或者拥有DROP ANY PROCEDURE系统权限的人。删除存储过程的语法如下:

1

DROP PROCEDURE 存储过程名;

6、如果要重新编译一个存储过程,则只能是过程的创建者或者拥有ALTER ANY PROCEDURE系统权限的人。语法如下:

1

ALTER PROCEDURE 存储过程名 COMPILE;

7、执行(或调用)存储过程的人是过程的创建者或是拥有EXECUTE ANY PROCEDURE系统权限的人,或是被拥有者授予EXECUTE 权限的人。执行的方法如下:

方法1:

1

EXECUTE 模式名.存储过程名[(参数...)];

方法2:

1

2

3

BEGIN

模式名.存储过程名[(参数...)];

END;

8、传递的参数必须与定义的参数类型、个数和顺序一致(如果参数定义了默认值,则调用时可以省略参数)。参数可以是变量、常量或表达式。

9、as和is的区别:在存储过程(procedure)和函数(function)中两者都可以使用,但是使用IS将无法使用调试模式调试该存储函数;在视图中只能用AS不能用IS,在游标(CURSOR)中只能用IS不能用AS。

10、oracle中的decode函数

含义解释:

阅读剩余部分

相关阅读 >>

sql存储过程的写法是什么

oracle存储过程是什么?

oracle的存储过程优缺点

存储过程在数据库中的作用是什么

解析mysql存储过程、常用函数代码

mysql存储过程的详细介绍(代码示例)

总结mysql存储过程in、out、inout参数示例

数据库存储过程要怎么写

mysql存储过程是什么样

mysql存储过程的优点是什么

更多相关阅读请进入《oracle数据库》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...