听说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来声明事务。
分享到:
相关推荐
hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程
使用hibernate的query调用oracle的存储过程/function,包含例子,源码以及数据库文件
java调用hibernate存储过程详细介绍,各种配置方法,还有与jdbc调用存储过程二者之间的对比。
hibernate本对数据库的操作有些不完美,有必要的时候可以调用存储过程来补足。
hibernate环境搭建已经对应存储过程调用
hibernate调用存储过程的方法,里面有典型的例题,欢迎大家下载
Hibernate 存储过程的调用.doc
在hibernate中调用oracle中的存储过程的详细代码。可以借鉴使用,帮助学习。
在hibernate中使用存储过程,调用存储过程
很好的hibernate开发技术,使用hibernate调用存储过程!
也可以通过存储过程来执行批量更新。存储过程直接在数据库中运行,速度更加快。在Oracle数据库中可以定义一个名为batchUpdateStudent()的存储过程。
hibernate调用存储过程.docx
Hibernate --调用存储过程(全)
hibernate3调用存储过程的用法详细介绍。
hibernate调用存储过程知识.pdf
前几天一直在搞spring+hibernate执行存储过程的技术,在网上查了很多资料没有一个是完全的能执行的,代码简单但,几天时间比较辛苦,所以要分多了点。由于包都太大,所以删掉啦!