hibernate存储过程调用
听说Hibenate3可以在执行存储过程了,但在网上了一些资料,基本上都是Hibernate文档中带的那个例子,其中也只是一个查询的例子。
现在我想执行一个插入功能的存储过程,试了几次都没有成功。如果那位有这样的成功经验愿请教!
以前做过用JAVA的JDBC执行存储过程,但即然都用Hiberante了。就不想再做一个数据库连接,想把这块都交给Hibernate管理。后来想到可以从Hibernate的Session 中再得到Connection啊,这样不就可以象在JDBC中一样执行存储过程了吗?一试,果然灵验。
代码:
存储过程自己写了。我用的MS SQL Server 2000
java code :
Session session = HibernateUtil.getSession(); //得到session
Transactiontx=session.beginTransaction();//开始事务
Connectioncon=session.connection();//从Session中得到Connection
Stringprocedure="{callinsertbankDate(?)}";//存储过程名,?是参数的位置,如果有多个参数就加多个?
CallableStatementcstmt=con.prepareCall(procedure);//这句可能是得到可以执行存储过程的Statement从网上查到的
cstmt.setString(1,"02");//设置参数
cstmt.executeUpdate();
tx.commit();好了。现在你的存储过程就可以Hibernate中执行了!------------------------------------------------------------------------------------------------------
如果底层数据库(如Oracle)支持存储过程,也可以通过存储过程来执行批量更新。存储过程直接在数据库中运行,速度更加快。在Oracle数据库中可以定义一个名为batchUpdateStudent()的存储过程,代码如下:
create or replace procedure batchUpdateStudent(p_age in number) as
begin
updateSTUDENTsetAGE=AGE+1whereAGE>p_age;
end;以上存储过程有一个参数p_age,代表学生的年龄,应用程序可按照以下方式调用存储过程:
tx = session.beginTransaction();Connection con=session.connection();
String procedure = "{call batchUpdateStudent(?) }";
CallableStatementcstmt=con.prepareCall(procedure);
cstmt.setInt(1,0);//把年龄参数设为0
cstmt.executeUpdate();
tx.commit();在以上代码中,我用的是Hibernate的 Transaction接口来声明事务,而不是采用JDBC API来声明事务。