`

Hibernate3.2版本对于存储过程调用的问题

阅读更多

最近看了hibernate3.2支持在hbm.xml文件通过<sql-query> 配置就可以进行存储过程的调用,于是便做了相关的实验

-- Create table
create table T_TEST
(
  ID   NUMBER not null,
  NAME VARCHAR2(30),
  SEX  VARCHAR2(30),
  AGE  NUMBER
)

 

而后是hbm.xml文件

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="test.Test" table="t_test" schema="HBM">
        <id name="id" column="id" type="int">
            <generator class="assigned"/>
        </id>
        <property name="name" column="name" type="string"></property>
        <property name="age" column="age" type="integer"></property>
        <property name="sex" column="sex" type="string"></property>
    </class>
   
    <sql-query name="getTestList" callable="true">    <!-- function -->
        <return alias="Test" class="test.Test">
            <return-property name="id" column="id"></return-property>
            <return-property name="name" column="name"></return-property>
            <return-property name="age" column="age"></return-property>
            <return-property name="sex" column="sex"></return-property>
        </return>
        {? = call getTestList(?)} --这个是函数的调用
    </sql-query>
     <sql-query name="cjjtlg" callable="true">    <!-- procedure -->
        <return alias="TTest" class="test.Test">
            <return-property name="id" column="id"></return-property>
            <return-property name="name" column="name"></return-property>
            <return-property name="age" column="age"></return-property>
            <return-property name="sex" column="sex"></return-property>
        </return>
        {call cjjtlg(?,?) }- -存储过程的调用 ,这里如果写成帮助文档里面{?=call cjjtlg(?,?) } 那必然是报告错误。
    </sql-query>
   
    <sql-query name="singleout" callable="true">    <!-- procedure -->
        <return alias="TTest" class="test.Test">
            <return-property name="name" column="name"></return-property>
        </return>
        {call singleout(?,?) }--带输出参数的调用
    </sql-query>
</hibernate-mapping>

 

 

 

Session session = HibernateSessionFactory.getSession();

Query query = session.getNamedQuery("cjjtlg");
query.setInteger(0, 1);

List<Test> list = query.list();
        for (int i = 0; i < list.size(); i++) {
            final Test t = list.get(i);
            System.err.println("id:" + t.getId() + ", name:" + t.getName()
                    + ", age:" + t.getAge() + ", sex:" + t.getSex());
        }
        System.err.println("count :" + list.size());
        System.err.println("----------finish----------\n");

 

对于存储过程的调用对于内嵌sql-query 这里面的,那么存储过程第一个参数必须是一个结果结,且必须是一个输出参数

那么才可以使用,特别注意到时候在进行query设置的时候参数忽略第一个参数,序列号从0开始,好比query.setInteger(0, 1);如此

存储过程如下

create or replace procedure cjjtlg(st_cursor out SYS_REFCURSOR,rowsid integer) is
begin
     open st_cursor for select * from t_test t where t.id=rowsid;
end cjjtlg;

query.setInteger(0, 1); 这个设置代表rowsid 这个参数是1,这点特别要注意。

 

如果很多读者要返回单个结果集,或者是执行某个存储过程想完成某个事项,返回参数不需要返回整个结果集,如果还想采用如此的方式进行,可以采用如下的方式来进行,只是在存储过程当中进行一些调整。

create or replace procedure singleout(st_cursor out SYS_REFCURSOR,rowsid integer) is
 temp_a varchar2(100);
begin
     --open st_cursor for select * from t_test t where t.id=rowsid;
     select t.sex into temp_a from t_test t where t.id = rowsid;
     open st_cursor for select temp_a as name,1 as id,1 as age,'man' as sex from dual;
end singleout;

这样的话,其他的调用方式跟上面一样的。

分享到:
评论
1 楼 coollifer 2011-04-10  
不错,关注老曹

相关推荐

    精通 Hibernate:Java 对象持久化技术详解(第2版).part2

     9.6 通过Hibernate调用存储过程  9.7 小结  9.8 思考题 第10章 映射组成关系  10.1 建立精粒度对象模型  10.2 建立粗粒度关系数据模型  10.3 映射组成关系  10.3.1 区分值(Value)类型和实体(Entity)类型...

    搞定J2EE:STRUTS+SPRING+HIBERNATE整合详解与典型案例 (1)

    1.4.8 RMI(远程方法调用) 1.4.9 JMS(Java消息服务) 1.4.10 JMX(Java分布式管理) 1.4.11 JACC(Java容器授权合同) 1.4.12 JCA(Java连接器体系) 1.5 小结 第二章 MVC模式介绍 2.1 MVC模式概述 2.1.1 MVC模式...

    搞定J2EE:STRUTS+SPRING+HIBERNATE整合详解与典型案例 (3)

    1.4.8 RMI(远程方法调用) 1.4.9 JMS(Java消息服务) 1.4.10 JMX(Java分布式管理) 1.4.11 JACC(Java容器授权合同) 1.4.12 JCA(Java连接器体系) 1.5 小结 第二章 MVC模式介绍 2.1 MVC模式概述 2.1.1 MVC模式...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part4

     9.6 通过Hibernate调用存储过程  9.7 小结  9.8 思考题 第10章 映射组成关系  10.1 建立精粒度对象模型  10.2 建立粗粒度关系数据模型  10.3 映射组成关系  10.3.1 区分值(Value)类型和实体(Entity)类型...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part3

     9.6 通过Hibernate调用存储过程  9.7 小结  9.8 思考题 第10章 映射组成关系  10.1 建立精粒度对象模型  10.2 建立粗粒度关系数据模型  10.3 映射组成关系  10.3.1 区分值(Value)类型和实体(Entity)类型...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part1.rar

     9.6 通过Hibernate调用存储过程  9.7 小结  9.8 思考题 第10章 映射组成关系  10.1 建立精粒度对象模型  10.2 建立粗粒度关系数据模型  10.3 映射组成关系  10.3.1 区分值(Value)类型和实体(Entity)类型...

    搞定J2EE:STRUTS+SPRING+HIBERNATE整合详解与典型案例 (2)

    1.4.8 RMI(远程方法调用) 1.4.9 JMS(Java消息服务) 1.4.10 JMX(Java分布式管理) 1.4.11 JACC(Java容器授权合同) 1.4.12 JCA(Java连接器体系) 1.5 小结 第二章 MVC模式介绍 2.1 MVC模式概述 2.1.1 MVC模式...

    ssh(structs,spring,hibernate)框架中的上传下载

    其中Hibernate 2相关的封装类位于org.springframework.orm.hibernate2.*包中,而Hibernate 3.0的封装类位于org.springframework.orm.hibernate3.*包中,需要根据您所选用Hibernate版本进行正确选择。  3、Lob字段...

    低清版 大型门户网站是这样炼成的.pdf

    5.12 hibernate调用存储过程 343 5.13 xml数据持久化 346 5.14 小结 348 第6章 充分利用spring 2.5的ioc利器统管bean世界 349 6.1 java程序员的春天厚礼—spring 2.5 349 6.1.1 爱上spring 2.5的十大理由 350 ...

    Spring攻略(第二版 中文高清版).part2

    3.2 用AspectJ注解声明aspect 115 3.2.1 问题 115 3.2.2 解决方案 115 3.2.3 工作原理 116 3.3 访问连接点信息 121 3.3.1 问题 121 3.3.2 解决方案 122 3.3.3 工作原理 122 3.4 指定aspect优先级 ...

    Spring攻略(第二版 中文高清版).part1

    3.2 用AspectJ注解声明aspect 115 3.2.1 问题 115 3.2.2 解决方案 115 3.2.3 工作原理 116 3.3 访问连接点信息 121 3.3.1 问题 121 3.3.2 解决方案 122 3.3.3 工作原理 122 3.4 指定aspect优先级 ...

    OpenID简介及与struts2_spring_hibernate框架集成

    3.2. Struts2的Action调用业务逻辑 - 19 - 3.2.1. 登录Action--OpenIDLoginAction - 19 - 3.2.2. 进入的Action—FirstPageAction - 20 - 3.3. JSP页面 - 20 - 3.4. 运行示例 - 21 - 3.4.1. 登录 - 21 - 3.4.2. ...

    Java Web程序设计教程

    4.3项目实战——存储图书信息 73 本章小结 78 课后练习 79 第5章struts2框架基础 80 5.1mvc框架 80 5.1.1model1与model2 80 5.1.2mvc设计模式 81 5.1.3struts2框架的mvc架构 82 5.2struts2概览 84 5.2.1...

    Spring.3.x企业应用开发实战(完整版).part2

    11.2.6 调用存储过程 11.3 BLOB/CLOB类型数据的操作 11.3.1 如何获取本地数据连接 11.3.2 相关的操作接口 11.3.3 插入Lob类型的数据 11.3.4 以块数据方式读取Lob数据 11.3.5 以流数据方式读取Lob数据 11.4 自增键和...

    Spring3.x企业应用开发实战(完整版) part1

    11.2.6 调用存储过程 11.3 BLOB/CLOB类型数据的操作 11.3.1 如何获取本地数据连接 11.3.2 相关的操作接口 11.3.3 插入Lob类型的数据 11.3.4 以块数据方式读取Lob数据 11.3.5 以流数据方式读取Lob数据 11.4 自增键和...

    Spring in Action(第2版)中文版

    5.4.1选择hibernate的版本 5.4.2使用hibernate模板 5.4.3建立基于hibernate的dao 5.4.4使用hibernate3上下文会话 5.5spring和java持久api 5.5.1使用jpa模板 5.5.2创建一个实体管理器工厂 5.5.3建立使用jpa的...

    Spring in Action(第二版 中文高清版).part2

    5.4.1 选择Hibernate的版本 5.4.2 使用Hibernate模板 5.4.3 建立基于Hibernate的DAO 5.4.4 使用Hibernate 3上下文会话 5.5 Spring和Java持久API 5.5.1 使用JPA模板 5.5.2 创建一个实体管理器工厂 5.5.3 建立...

    Spring in Action(第二版 中文高清版).part1

    5.4.1 选择Hibernate的版本 5.4.2 使用Hibernate模板 5.4.3 建立基于Hibernate的DAO 5.4.4 使用Hibernate 3上下文会话 5.5 Spring和Java持久API 5.5.1 使用JPA模板 5.5.2 创建一个实体管理器工厂 5.5.3 建立...

    工程硕士学位论文 基于Android+HTML5的移动Web项目高效开发探究

    目前市场业务中在产品以及其他项目的认证和检测方面存在诸多不便,用户需要实地考察并频繁与检测单位沟通,填写繁琐的纸质检测报告、当面送递样品,对于检测环节中存在的问题难以及时交互并处理。市场上相应的检测...

Global site tag (gtag.js) - Google Analytics