在Hibernate中执行存储过程

来源:互联网 发布:mac专柜口红价格表 编辑:程序博客网 时间:2024/05/17 08:51

听说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中执行了!

 

原创粉丝点击