`
jiaguwen123
  • 浏览: 406533 次
  • 性别: Icon_minigender_2
  • 来自: 深圳
社区版块
存档分类
最新评论

hibernate存储过程调用

阅读更多

听说Hibenate3可以在执行存储过程了,但在网上了一些资料,基本上都是Hibernate文档中带的那个例子,其中也只是一个查询的例子。

现在我想执行一个插入功能的存储过程,试了几次都没有成功。如果那位有这样的成功经验愿请教!

以前做过用JAVA的JDBC执行存储过程,但即然都用Hiberante了。就不想再做一个数据库连接,想把这块都交给Hibernate管理。后来想到可以从Hibernate的Session 中再得到Connection啊,这样不就可以象在JDBC中一样执行存储过程了吗?一试,果然灵验。

代码:

存储过程自己写了。我用的MS SQL Server 2000

java code :

Session session = HibernateUtil.getSession(); //得到session
Transaction tx = session.beginTransaction(); //开始事务
Connection con = session.connection(); //从Session 中得到Connection
String procedure = "{call insertbankDate(?) }"; //存储过程名,?是参数的位置,如果有多个参数就加多个?
CallableStatement cstmt = 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
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来声明事务。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics