注:原创作品,转载请注明出处。
上篇博文介绍的是hibernate调用返回单值的存储过程,本片博文说的是hibernate调用返回游标的存储过程。
此此扁博文的存储过程的功能相当于是jdbc调用select 的作用。
1,创建oracle中的包,并在该包中创建的游标类型。
---创建oracle的程序包,在该包中创建一个游标类型
--该类型在存储过程中用来生命输出参数的类型
create or replace package pkg_return_list
as
type list_cursor is ref cursor;
end pkg_return_list;
2,创建oracle存储过程,该存储过程有唯一的输出参数。
--创建从java程序调用的存储过程,注意该存储过程的唯一输出
--参数的类型是个游标类型。
create or replace procedure pro_return_list(p_cursor out pkg_return_list.list_cursor)
as
begin
open p_cursor for select * from TBL_ADDRESS;
end pro_return_list;
3,java调用存储过程的主程序。
package com.supan.test;
import com.supan.dao.imp.UserDaoImp;
public class hibernate1
{
public static void main(String[] args)
{
UserDaoImp udi = new UserDaoImp();
udi.callprocedureOfCursor();
}
}
4,java的dao层方法
//调用返回游标的存储过程
public void callprocedureOfCursor()
{
//没有spring的注入,只有人工苦逼的注册sessionFactory属性
Configuration cof = new Configuration().configure();
this.setSessionFactory(cof.buildSessionFactory());
//定义存放结果的结果map
final Map<String,String> result = new HashMap<String, String>();
getHibernateTemplate().execute(new HibernateCallback<Object>()
{
@Override
public Object doInHibernate(Session session)
throws HibernateException, SQLException
{
session.doWork(new Work()
{
@Override
public void execute(Connection conn) throws SQLException
{
CallableStatement proc = null;
ResultSet rs = null;
try
{
proc = conn.prepareCall("{call pro_return_list(?)}");
//注意:这里是注册输出参数的类型
proc.registerOutParameter(1, oracle.jdbc.OracleTypes.CURSOR);
//执行存储过程
proc.execute();
//获取存储过程的输出参数
rs = (ResultSet)proc.getObject(1);
while(rs.next())
{
//注意访问结果集是从索引位置1开始的,而不是0
System.out.println(rs.getLong(1));
System.out.println(rs.getString(2));
System.out.println(rs.getString(3));
System.out.println(rs.getString(4));
System.out.println("----------------");
}
}
catch(Exception e)
{
//logger.error("访问数据库失败");
e.printStackTrace();
}
finally
{
if(null != proc)
{
try
{
proc.close();
} catch (Exception e2)
{
//logger.error(close proc happend error);
e2.printStackTrace();
}
}
}
}
});
return null;
}
});
}
分享到:
相关推荐
游标 存储过程游标 存储过程
游标创建 存储过程创建 程序调用游标 程序调用存储过程
C#winform调用带输出游标和其它输出参数的oralce存储过程示例,有需要的网友可参考参考,实测通过
birt报表中调用存储过程的方法. 目录 1. 概述 3 2. BIRT支持的存储过程返回值类型 3 3. BIRT调用存储过程的语法 4 ... 调用返回游标的存储过程 7 调用返回多个结果集的存储过程 8 6. 参考文档和资源 11
利用SQL游标存储过程分页方案,以前用过,应该还行
讲有关java如何调用ORACLE存储过程以及游标使用,它只包含JAVA调用ORACLE存储过程游标使用(上),还有JAVA调用ORACLE存储过程游标使用(上),
NULL 博文链接:https://fruitking.iteye.com/blog/1447333
利用游标返回结果集的的例子(Oracle 存储过程).doc 利用游标返回结果集的的例子(Oracle 存储过程).doc 利用游标返回结果集的的例子(Oracle 存储过程).doc
第一种情况是返回的游标是某个具体的表或视图的数据,如: SQL-Code: 代码如下: CREATE OR REPLACE PROCEDURE P_TESTA ( PRESULT OUT SYS_REFCURSOR ) AS BEGIN OPEN PRESULT FOR SELECT * FROM USERS; END P_TESTA;...
ibatis调存储过程返回游标,资料整理
存储过程中通过返回数据集,通过游标方式实现,以及在java中如何接收的整个过程
用callabledStatement调用oracle存储过程实用例子(IN OUT 传参数包括游标类型)
带游标的mysql存储过程例子。
实验八数据库编程技术——游标、存储过程与触发器.pdf
Mysql存储过程游标触发器
Oracle Package有简化应用设计、提高应用性能、实现信息隐藏、子程序重载作用。本文举例说明了Oracle Package中返回游标的写法和调用。
Pb 调用 DECLARE lpro_test PROCEDURE FOR proc_pslx; EXECUTE lpro_test ; 存储过程 CREATE PROCEDURE proc_pslx AS insert into demo(name) values('55566') GO
sql 存储过程常用函数及游标用法 这里包括 字符函数,数据库维护命令,所有游标的用法以及日期函数