码迷,mamicode.com
首页 > 数据库 > 详细

java hibernate 调用oracle存储过程

时间:2014-12-03 22:51:58      阅读:259      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   io   ar   color   os   sp   java   

1.hibernate 调用存储过程 各种方法

http://www.cnblogs.com/jerryxing/archive/2012/04/28/2475762.html

如果底层数据库(如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来声明事务。

3.有返回值的存储过程

Session session = this.getHibernateTemplate().getSessionFactory().getCurrentSession();
CallableStatement cs = session.connection().prepareCall("{call Tj(?,?,?,?,?,?,?)}");//存储过程的名字,?是传入的参数
 
//设置参数值 我这里是设置了7个参数
cs.setString(1, startTime);
cs.setString(2, endTime);
cs.setString(3,"");
cs.setString(4,"5");
cs.setString(5,"60");
cs.setString(6,"240");
cs.setString(7,orderby);
 
//执行查询
ResultSet rs = cs.executeQuery();
while (rs.next()) {
System.out.println(rs.getInt(1));
}
 
上面的方式是返回了一个ResultSet
第二种方法:
通过强大的createSQLQuery来实现
    1. Session session =HibernateSessionFactory.getSession();   
    2. SQLQuery query = session.createSQLQuery("{Call Tj(?)}"); //这里调用存储过程
    3. query.setString(1,"ddd");
    4. List list =query.list();  
    5. session.close(); 

java hibernate 调用oracle存储过程

标签:style   blog   http   io   ar   color   os   sp   java   

原文地址:http://www.cnblogs.com/mingtian521/p/4141288.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!