oracle存储过程(语法实例)

  • 格式:doc
  • 大小:112.50 KB
  • 文档页数:19

下载文档原格式

  / 19
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Oracl e 存储过程学习资料(内部适用)

目录

Oracle 存储过程1

Oracle存储过程基础知识2

Oracle存储过程的基本语法3

关于Oracle存储过程的若干问题备忘5

1.在Oracle中,数据表别名不能加as。5

2.在存储过程中,select某一字段时,后面必须紧跟into,如果select整个记录,利用

游标的话就另当别论了。5

3.在利用select...into...语法时,必须先确保数据库中有该条记录,否则会报出"no data

found"异常。5

4.在存储过程中,别名不能和字段名称相同,否则虽然编译可以通过,但在运行阶段会

报错5

5.在存储过程中,关于出现null的问题6

6.Hibernate调用Oracle存储过程6

用Java调用Oracle存储过程总结6

一、无返回值的存储过程7

二、有返回值的存储过程(非列表)8

三、返回列表10

在存储过程中做简单动态查询11

一、本地动态SQL12

二、使用DBMS_SQL包14

Oracle存储过程调用Java方法16

Oracle高效分页存储过程实例17

Oracle存储过程基础知识

商业规则和业务逻辑可以通过程序存储在Oracle中,这个程序就是存储过程。

存储过程是SQL, PL/SQL, Java 语句的组合,它使你能将执行商业规则的代码从你的应用程序中移动到数据库。这样的结果就是,代码存储一次但是能够被多个程序使用。

要创建一个过程对象(procedural object),必须有CREATE PROCEDURE 系统权限。如果这个过程对象需要被其他的用户schema 使用,那么你必须有CREATE ANY PROCEDURE 权限。执行procedure 的时候,可能需要excute权限。或者EXCUTE ANY PROCEDURE 权限。如果单独赋予权限,如下例所示:

grant execute on MY_PROCEDURE to Jelly

调用一个存储过程的例子:

execute MY_PROCEDURE( 'ONE PARAMETER');

存储过程(PROCEDURE)和函数(FUNCTION)的区别。function有返回值,并且可以直接在Query中引用function和或者使用function的返回值。

本质上没有区别,都是PL/SQL 程序,都可以有返回值。最根本的区别是:存储过程是命令, 而函数是表达式的一部分。比如:

select max(NAME) FROM

但是不能exec max(NAME) 如果此时max是函数。

PACKAGE是function,procedure,variables 和sql 语句的组合。package允许多个procedure使用同一个变量和游标。

创建procedure的语法:

可以使用create or replace procedure 语句,这个语句的用处在于,你之前赋予的excute 权限都将被保留。

IN, OUT, IN OUT用来修饰参数。

IN 表示这个变量必须被调用者赋值然后传入到PROCEDURE进行处理。

OUT 表示PRCEDURE 通过这个变量将值传回给调用者。

IN OUT 则是这两种的组合。

authid代表两种权限:

定义者权限(difiner right 默认),执行者权限(invoker right)。

定义者权限说明这个procedure中涉及的表,视图等对象所需要的权限只要定义者拥有权限的话就可以访问。

执行者权限则需要调用这个procedure的用户拥有相关表和对象的权限。

Oracle存储过程的基本语法

将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND)

连接数据库后建立一个Test WINDOW

在窗口输入调用SP的代码,F9开始debug,CTRL+N单步调试

9.Pl/Sql中执行存储过程

在sql*plus中:

注:在EXECUTE IMMEDIATE STR语句是SQLPLUS中动态执行语句,它在执行中会自动提交,类似于DP中FORMS_DDL语句,在此语句中str是不能换行的,只能通过连接字符"||",或着在在换行时加上"-"连接字符。

关于Oracle存储过程的若干问题备忘

1.在Oracl e中,数据表别名不能加as。

如:

select a.appname from appinfo a;-- 正确

select a.appname from appinfo as a;-- 错误

也许,是怕和Oracle中的存储过程中的关键字as冲突的问题吧

2.在存储过程中,select某一字段时,后面必须紧跟into,

如果sel ect整个记录,利用游标的话就另当别论了。

select af.keynode into kn

from APPFOUNDATION af

where af.appid=aid and af.foundationid=fid;-- 有into,正确编译

select af.keynode

from APPFOUNDATION af

where af.appid=aid and af.foundationid=fid;-- 没有into,编译报错,提示:Compilation Error: PLS-00428: an INTO clause is expected in this SELECT statement

3.在利用select...into...语法时,必须先确保数据库中有该条

记录,否则会报出"no data found"异常。

可以在该语法之前,先利用select count(*) from 查看数据库中是否存在该记录,如果存在,再利用select...into...

4.在存储过程中,别名不能和字段名称相同,否则虽然编译

可以通过,但在运行阶段会报错

select keynode into kn from APPFOUNDATION where appid=aid and foundationid=fid;

-- 正确运行

select af.keynode into kn from APPFOUNDATION af where af.appid=appid and af.foundationid