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