文档详情

《oracle存储过程学习经典》.pdf

发布:2015-12-28约2.24万字共18页下载文档
文本预览下载声明
Oracle 存储过程学习 目录 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 [ schema.]procedure [(argument [IN | OUT | IN OUT ] [NO COPY] datatype [, argument [IN | OUT | IN OUT ] [NO COPY] datatype]... )] [ authid { current_user | definer }] { is | as } { pl/sql_subprogram_body | language { java name String | c [ name, name] library lib_name }] Sql 代码: CREATE PROCE
显示全部
相似文档