Oracle存储过程学习
目录
Oracle存储过程 (1)
Oracle存储过程基础知识 (1)
Oracle存储过程的基本语法 (2)
关于Oracle存储过程的若干问题备忘 (4)
1.在Oracle中,数据表别名不能加as。 (4)
2.在存储过程中,select某一字段时,后面必须紧跟into,如果select整个记录,利
用游标的话就另当别论了。 (5)
3.在利用语法时,必须先确保数据库中有该条记录,否则会报出"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)
O racle存储过程基础知识
商业规则和业务逻辑可以通过程序存储在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');
FUNCTION))的区别。
存储过程(PROCEDURE
PROCEDURE))和函数(FUNCTION
function有返回值,并且可以直接在Query中引用function和或者使用function的返回值。
本质上没有区别,都是PL/SQL程序,都可以有返回值。最根本的区别是:存储过程是命令,而函数是表达式的一部分。比如:
select max(NAME)FROM
但是不能exec max(NAME)如果此时max是函数。
PACKAGE是function,procedure,variables和sql语句的组合。package允许多个procedure使用同一个变量和游标。
创建procedure的语法:
excute权限都将被保留。
OUT,,IN OUT用来修饰参数。
IN,OUT
IN表示这个变量必须被调用者赋值然后传入到PROCEDURE进行处理。
OUT表示PRCEDURE通过这个变量将值传回给调用者。
IN OUT则是这两种的组合。
authid代表两种权限:
定义者权限(difiner right默认),执行者权限(invoker right)。
定义者权限说明这个procedure中涉及的表,视图等对象所需要的权限只要定义者拥有权限的话就可以访问。
执行者权限则需要调用这个procedure的用户拥有相关表和对象的权限。
O racle存储过程的基本语法
1.基本结构
CREATE OR REPLACE PROCEDURE存储过程名字app开发实例
(
参数1IN NUMBER,
参数2IN NUMBER
)AS
变量1INTEGER:=0;
变量2DATE;
BEGIN
END存储过程名字
2.SELECT INTO STATEMENT
将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND)
例子:
BEGIN
SELECT col1,col2into变量1,变量2FROM typestruct where xxx;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xxxx;
END;
...
3.IF判断
IF V_TEST=1THEN
BEGIN
do something
END;
END IF;
4.while循环
WHILE V_TEST=1LOOP
BEGIN
XXXX
END;
END LOOP;
5.变量赋值
V_TEST:=123;
6.用for in使用cursor
...
IS
CURSOR cur IS SELECT*FROM xxx;
BEGIN
FOR cur_result in cur LOOP
BEGIN
V_SUM:=cur_result.列名1+cur_result.列名2
END;
END LOOP;
END;
7.带参数的cursor
CURSOR C_USER(C_ID NUMBER)IS SELECT NAME FROM USER WHERE TYPEID=C_ID;
OPEN C_USER(变量值);
LOOP
FETCH C_USER INTO V_NAME;
EXIT FETCH C_USER%NOTFOUND;
do something
END LOOP;
CLOSE C_USER;
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,
如果select整个记录,利用游标的话就另当别论了。
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.在利用语法时,必须先确保数据库中有该条
记录,否则会报出"no data found"异常。
可以在该语法之前,先利用select count(*)from查看数据库中是否存在该记录,如果存在,再利用
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的问题
假设有一个表A,定义如下:
create table A(
id varchar2(50)primary key not null,
vcount number(8)not null,
bid varchar2(50)not null--外键
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论