hibernate中调用存储过程
2009-02-17 17:14
453 查看
如果底层数据库(如Oracle)支持存储过程,也可以通过存储过程来执行批量更新。存储过程直接在数据库中运行,速度更加快。在Oracle数据库中可以定义一个名为batchUpdateStudent()的存储过程,代码如下:
create or replace procedure batchUpdateStudent(p_age in number) as
begin
update STUDENT set AGE=AGE+1 where AGE>p_age;
end;
以上存储过程有一个参数p_age,代表学生的年龄,应用程序可按照以下方式调用存储过程:
tx = session.beginTransaction();
Connection con=session.connection();
String procedure = "{call batchUpdateStudent(?) }";
CallableStatement cstmt = con.prepareCall(procedure);
cstmt.setInt(1,0); //把年龄参数设为0
cstmt.executeUpdate();
tx.commit();
在以上代码中,我用的是Hibernate的 Transaction接口来声明事务,而不是采用JDBC API来声明事务。
hibernate3开始支持存储过程查询特性了;
注意:因为是"存储过程查询特性"所以只能调用,返回结果集的存储过程;
例如返回,tuer的结果集
需要在TUer的hbm.xml下
<sql-query name="getUserByAge" callable="true">
<return alias="user" class="po.TUser">
<return-property name="id" column="ID"/>
<return-property name="name" column="Name"/>
<return-property name="age" column="Age"/>
{? = call getUserByAge(?)}
</sql-query>
create or replace procedure batchUpdateStudent(p_age in number) as
begin
update STUDENT set AGE=AGE+1 where AGE>p_age;
end;
以上存储过程有一个参数p_age,代表学生的年龄,应用程序可按照以下方式调用存储过程:
tx = session.beginTransaction();
Connection con=session.connection();
String procedure = "{call batchUpdateStudent(?) }";
CallableStatement cstmt = con.prepareCall(procedure);
cstmt.setInt(1,0); //把年龄参数设为0
cstmt.executeUpdate();
tx.commit();
在以上代码中,我用的是Hibernate的 Transaction接口来声明事务,而不是采用JDBC API来声明事务。
hibernate3开始支持存储过程查询特性了;
注意:因为是"存储过程查询特性"所以只能调用,返回结果集的存储过程;
例如返回,tuer的结果集
需要在TUer的hbm.xml下
<sql-query name="getUserByAge" callable="true">
<return alias="user" class="po.TUser">
<return-property name="id" column="ID"/>
<return-property name="name" column="Name"/>
<return-property name="age" column="Age"/>
{? = call getUserByAge(?)}
</sql-query>
相关文章推荐
- Hibernate如何调用存储过程
- Hibernate 调用存储过程总结-------都能成功
- hibernate 调用存储过程
- hibernate中调用存储过程
- Hibernate如何调用存储过程
- Hibernate调用存储过程示例(有参数,返回结果集)
- Hibernate调用存储过程
- Hibernate3.x调用存储过程【转】
- Hibernate调用执行存储过程
- 用hibernate调用存储过程
- Hibernate如何调用存储过程
- Hibernate DAO层调用存储过程方法
- hibernate中调用存储过程hibernate中调用存储过程
- hibernate调用mysql5.0存储过程
- Hibernate 3.2 如何调用存储过程
- java 中 用到的jdbc 调用存储过程,与hibernate 调用存储过程
- Hibernate 调用原生态Sql语句和存储过程
- SSH框架的hibernate调用存储过程并拿到存储过程的返回值
- Hibernate中调用存储过程
- hibernate调用存储过程