Oracle+PlSql存储过程 学习文档
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Oracl e 存储过程
目录
Oracle 存储过程 (1)
Oracle存储过程基础知识 (1)
Oracle存储过程的基本语法 (2)
关于Oracle存储过程的若干问题备忘 (4)
1. 在Oracle中,数据表别名不能加as。 (4)
2. 在存储过程中,select某一字段时,后面必须紧跟into,如果select整个记录,利
用游标的话就另当别论了。 (5)
3. 在利用select...into...语法时,必须先确保数据库中有该条记录,否则会报出"no data
found"异常。 (5)
4. 在存储过程中,别名不能和字段名称相同,否则虽然编译可以通过,但在运行阶段
会报错 (5)
5. 在存储过程中,关于出现null的问题 (5)
6. Hibernate调用Oracle存储过程 (6)
用Java调用Oracle存储过程总结 (6)
一、无返回值的存储过程 (6)
二、有返回值的存储过程(非列表) (8)
三、返回列表 (9)
在存储过程中做简单动态查询 (11)
一、本地动态SQL (12)
二、使用DBMS_SQL包 (13)
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)
例子:
8.用pl/sql developer debug
连接数据库后建立一个Test WINDOW
在窗口输入调用SP的代码,F9开始debug,CTRL+N单步调试
9.Pl/Sql中执行存储过程
提交,类似于DP中FORMS_DDL语句,在此语句中str是不能换行的,只能通过连接字符"||",或着在在换行时加上"-"连接字符。
关于Oracle存储过程的若干问题备忘
1.在Oracle中,数据表别名不能加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 =foundationid;
-- 运行阶段报错,提示:
ORA-01422:exact fetch returns more than requested number of rows
5.在存储过程中,关于出现null的问题
create table A(
id varchar2(50) primary key not null,
vcount number(8) not null,
bid varchar2(50) not null -- 外键
);