oracle 存储过程,函数和包
AS
PLSQL子程序体;
调用 存储过程的方式 两种
1、execute(exec) ------exec 函数名()
2、begin
函数名()
end -------begin 函数名()end
CREATE [OR REPLACE] FUNCTION 函数名(参数列表)
RETURN 函数值类型
AS
PLSQL子程序体;
一般来讲,过程和函数的区别在于函数可以有一个返回值;而过程没有返回值。
但过程和函数都可以通过out指定一个或多个输出参数。
我们可以利用out参数,在过程和函数中实现返回多个值。
如果只有一个返回值,用存储函数;否则,就用存储过程。
一般不在存储过程和存储函数中做提交和回滚操作
如果一个存储过程中含有很多个返回值,需要在存储过程中全部写出来,比较的不方便,所以可以让存储过程中返回一个指针进行处理,即包
--存储过程
create or replace procedure getEmpInfo(eno in testemp.empno%type,--输入值in可以省略
empname out varchar,--输出值out必须要,只需要写返回类型,不需要写精度
empjob out varchar,
empsal out number
)
as
begin
select ename,job,sal into empname,empjob,empsal from testemp where empno=eno;
end; --函数 create or replace function getSals(eno in testemp.empno%type)
return testemp.sal%type --定义返回类型
as
psal testemp.sal%type;
pcomm testemp.comm%type;
begin
select sal,comm into psal,pcomm from testemp where empno=eno;
return (psal*12+nvl(pcomm,0)); --返回值
end; --创建包
create or replace package mypackage as--mypackage 自定义包名
type empcursor is ref cursor;--声明一个自定义光标类型
procedure queryemp(dtno in testemp.deptno%type,
empinfo out empcursor );--存储过程
end mypackage;--结束包头定义 create or replace --创建包体
package body mypackage as
procedure queryemp(dtno in testemp.deptno%type,empinfo out empcursor) as
begin
open empinfo for select * from testemp where deptno=dtno;--将查询到的数据放到光标中
end queryemp;
end mypackage;
在java中调用存储过程,函数
1、导包
在oracle安装目录product10.2.0\db_1\jdbc\lib目录下。默认在C:\oracle\product\10.2.0\db_1\jdbc\lib
2、
java连接oracle驱动
private static String driver="oracle.jdbc.OracleDriver";
private static String url="jdbc:oracle:thin:@192.168.250.144:1521:orcl";
private static String user="scott";
private static String password="tiger";
3、
调用存储过程
String sql="{call getEmpInfo(?,?,?,?)}";//调用存储过程sql语句
Connection conn=null;
CallableStatement callStatement=null;
try {
conn=OracleUtils.getConnection();
callStatement=conn.prepareCall(sql);
callStatement.setInt(1, 7839);//设置输入值
callStatement.registerOutParameter(2,OracleTypes.VARCHAR);//设置输出值
callStatement.registerOutParameter(3,OracleTypes.VARCHAR);
callStatement.registerOutParameter(4,OracleTypes.NUMBER); callStatement.execute();//执行存储过程 String name=callStatement.getString(2);//获取输出值
String job=callStatement.getString(3);
double sal=callStatement.getDouble(4); System.err.println("name="+name);
System.err.println("job="+job);
System.err.println("sal="+sal); } catch (Exception e) {
e.printStackTrace();
}finally{
OracleUtils.release(conn, callStatement, null);
}
调用函数
String sql="{?= call getSals(?)}";
Connection conn=null;
CallableStatement call=null;
try {
conn=OracleUtils.getConnection();
call=conn.prepareCall(sql);
call.registerOutParameter(1, OracleTypes.NUMBER);
call.setInt(2, 7839); call.execute(); double allsal=call.getDouble(1); System.err.println(allsal); } catch (Exception e) {
e.printStackTrace();
}finally{
OracleUtils.release(conn, call, null);
}
调用带有光标返回值得包
String sql="{call mypackage.queryemp(?,?)}";
Connection conn=null;
CallableStatement call=null;
ResultSet rs=null;
try {
conn=OracleUtils.getConnection();
call=conn.prepareCall(sql);
call.setInt(1, 30);
call.registerOutParameter(2, OracleTypes.CURSOR); call.execute(); rs=((OracleCallableStatement)call).getCursor(2);//获取光标值的结果集
while(rs.next())//循环光标
{
String name=rs.getString("ename");
String job=rs.getString("job");
System.err.println("name:"+name+" job:"+job); } } catch (Exception e) {
e.printStackTrace();
}
oracle 存储过程,函数和包的更多相关文章
- Oracle存储过程和程序包
一.为什么要用存储过程? 如果在应用程序中经常需要执行特定的操作,可以基于这些操作简历一个特定的过程.通过使用过程可以简化客户端程序的开发和维护,而且还能提高客户端程序的运行性能. 二.过程的优点? ...
- oracle 过程函数,包的区别和联系
一.过程与函数区别 1.过程可以有0~N个返回参数,通过OUT or IN OUT参数返回:函数有且仅有1个返回值,通过return语句返回. 2.调用过程时,可做为单独的语句执行:调用函数时,函数必 ...
- oracle存储过程函数
1.函数 create or replace function get_Destroy_no return varchar2 is Result varchar2(50);begin SELECT m ...
- Oracle存储过程 函数 计算使用资源
目录 存储过程与函数 存储过程的优势 存储过程 打印语句 选择语句 函数 计算使用资源 存储过程与函数 存储过程的优势 存储过程 /* 多行注释 */ -- 单行注释 //展示错误信息 show er ...
- hibernate调用oracle存储过程||函数
pakeage dao.Impl; //调用函数FUN_GET(); public String get(String Id,String Name){ return getSession().cre ...
- Oracle中如何导出存储过程、函数、包和触发器的定义语句?如何导出表的结构?如何导出索引的创建语句?
Oracle中如何导出存储过程.函数.包和触发器的定义语句?如何导出表的结构?如何导出索引的创建语句? QQ群里有人问:如何导出一个用户下的存储过程? 麦苗答:方法有多种,可以使用DBMS_MET ...
- oracle 存储过程,存储函数,包,
http://heisetoufa.iteye.com/blog/366957 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的PL/SQL块.但存储过程和函数不同于已经介绍过 ...
- oracle中函数和存储过程的区别和联系【转载竹沥半夏】
oracle中函数和存储过程的区别和联系[转载竹沥半夏] 在oracle中,函数和存储过程是经常使用到的,他们的语法中有很多相似的地方,但也有自己的特点.刚学完函数和存储过程,下面来和大家分享一下自己 ...
- oracle 存储过程 包 【转】
一.为什么要用存储过程? 如果在应用程序中经常需要执行特定的操作,可以基于这些操作简历一个特定的过程.通过使用过程可以简化客户端程序的开发和维护,而且还能提高客户端程序的运行性能. 二.过程的优点? ...
- oracle PL/SQL(procedure language/SQL)程序设计之函数+过程+包
匿名PL/SQL块回顾 DECLARE (可选) 定义在PL/SQL块中要使用的对象BEGIN (必须) 执行语句EXCEPTION (可选) 错误处理语句END; (必须)匿名块( ...
随机推荐
- 一、UITableView的属性
一.UITableView的属性 NSIndexPath类型是用来获取用户选择的indexPath,在别的函数里面,若需要知道用户选择了哪个cell,用上它可以省事很多.不必再去建全局变量sectio ...
- c语言用封装来优化程序
一.基础研究 先对函数fa进行研究,代码如下: fa函数的参数为一个字符指针,他存储要输出的字符串.因为要显示在屏幕的中央位置,所以我们要把字符串放在段地址b800处.用strlen获取字符串的长度, ...
- zoj 3777 Problem Arrangement
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5264 题意:给出n道题目以及每一道题目不同时间做的兴趣值,让你求出所有做题顺序 ...
- 【HDOJ】1314 Numerically Speaking
学了几天的Java了,终于独立A了一道大数计算.感觉还得练Java啊. import java.util.Scanner; import java.math.BigInteger; import ja ...
- Wormholes 最短路判断有无负权值
Description While exploring his many farms, Farmer John has discovered a number of amazing wormholes ...
- [Design Pattern] Service Locator Pattern 简单案例
Service Locator Pattern,即服务定位模式,用于定位不同的服务.考虑到 InitialContext::lookup 的成本比较高,提供了 Cache 类缓存以定位到的服务. 代码 ...
- java文件(文件夹)操作
java中文件操作 判断是否为文件file.isFile()方法 判断是否为目录file.isDirectory()方法 判断是否存在file.exist()方法 创建新文件file.createNe ...
- js用for循环为对象添加事件并传递参数
var objArr = getObjArr(id); for(var i=0; i<objArr.length; i++){ var param=objArr.param ad ...
- Office2007图标变成白框,但是还能使用问题解决办法
在Windows 8中,Office图标变成白框了.不能显示. 解决办法:从其他电脑的Windows\Installer中拷贝一下所有文件夹到问题电脑.然后重启,问题解决. {90120000-002 ...
- windows 编程—— 宽字符集 与 Unicode
目录: 从ASCII码 到 Unicode Windows 编程中的 "字符” 定义 (如何在windows下进行通用编码) 常用的通用函数,定义 (本文为学习<Programming ...