如果底层数据库(如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>
hibernate中调用存储过程
最新推荐文章于 2014-12-25 14:24:32 发布