当前位置:首页 > 开发 > 数据库 > 正文

hibernate调用返回游标的存储过程

发表于: 2014-08-05   作者:Supanccy2013   来源:转载   浏览:
摘要: 注:原创作品,转载请注明出处。     上篇博文介绍的是hibernate调用返回单值的存储过程,本片博文说的是hibernate调用返回游标的存储过程。     此此扁博文的存储过程的功能相当于是jdbc调用select 的作用。 1,创建oracle中的包,并在该包中创建的游标类型。 ---创建oracle的程
注:原创作品,转载请注明出处。


    上篇博文介绍的是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;
			}
		});
}

hibernate调用返回游标的存储过程

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
最近在用ibatis.net框架和oracle 11g开发一套程序。其中有一个需求就是通过存储过程,查询指定条件
1.hibernate3   到这下载hibernate3:http://sourceforge.net/project/showfiles.phpgroup_id=40712
我在做项目的时候 一直在为分页查询而头疼,于是我前两天我写了一个通用的存储过程分页 然后在hibern
1.hibernate3   到这下载hibernate3:http://sourceforge.net/project/showfiles.phpgroup_id=40712
1.hibernate3   到这下载hibernate3:http://sourceforge.net/project/showfiles.phpgroup_id=40712
将原来联系人的名字和性别导入到接听秘书电话方式的留言里面.sql create proc cmantoleave_mess as
游标 声明游标 declare cursor cursor_name is select * from tablename 打开游标 open cursor_name
链接:http://www.codeproject.com/Articles/675933/Returning-Multiple-Result-Sets-from-an-Entit
基础内容: 表变量 临时表在这个会话中存在,而变量是存在你所需要的块中 比如说包啊 过程 函数等中
一、命名查询 HQL语句混杂在代码之间将破坏代码的可读性 Hibernate允许在映射配置文件中定义字符串
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号