hibernate如何调用存储过程

12 篇文章 0 订阅

一般我们用PL/SQL写好存储过程后,用JDBC调用的比较多,如何你想用hibernate,那怎么调用存储过程呢?

下面我们来看看Hibernate调用Oracle的存储过程 的几种方式


1.先创建一个存储过程如下:
create Procedure proc()
begin
      select * from user;
end;
     
create procedure  proc1(v_no number(4))
begin
     select * from user where empno=v_no;
 end;
 

2.编写hibernate映射关系
存储过程映射和领域模型中的实体的对应关系
 <class name="com.test.User" table="user">     
          <id name="id" column="id">     
              <generator class="native"/>     
          </id>     
          <property name="name" column="name" type="string" />     
          <property name="age" column="age" type="integer" />     
  </class>     
     <sql-query name="getUser" callable="true">     
       <return alias="user" class="com.test.User">     
      <return-property name="id" column="id" />     
      <return-property name="name" column="name" />     
      <return-property name="age" column="age" />     
      </return>     
      {call proc()}     
    </sql-query>    

3Hibernate API 对存储过程的调用:
 Session ss= HibernateSessionFactory.getSession()     
 List li=ss.getNamedQuery("getUser").list();     
 ss.close();    
 
         Session ss= HibernateSessionFactory.getSession()  
         List li=ss.getNamedQuery("getUser").list();  
         ss.close(); 
 
  4.JDBC API 对存储过程的调用
 Session session =HibernateSessionFactory.getSession();      
 Connection conn = session.connection();      
 ResultSet rs =null;     
  CallableStatement call = conn.prepareCall("{Call proc()}");     
  rs = call.executeQuery();     
 rs.close();     
 session.close();    
 
  Session session =HibernateSessionFactory.getSession();   
 Connection conn = session.connection();   
 ResultSet rs =null;  
 CallableStatement call = conn.prepareCall("{Call proc()}");  
 rs = call.executeQuery();  
 rs.close();  
 session.close(); 


5.直接使用 Hibernate  createQuerySql调用存储过程
 Session session =HibernateSessionFactory.getSession();      
 SQLQuery query = session.createSQLQuery("{Call proc()}");     
 List list =query.list();     
session.close();    
 
Session session =HibernateSessionFactory.getSession();   
 SQLQuery query = session.createSQLQuery("{Call proc()}");  
 List list =query.list();  
 session.close(); 





6.通过Hibernate API或者JDBC,API给存储过程传参
CallableStatement call = conn.prepareCall("{Call proc(?)}");     
 call.setString(1, 参数);     
rs = call.executeQuery();    
 
 CallableStatement call = conn.prepareCall("{Call proc(?)}");  
 call.setString(1, 参数);  
 rs = call.executeQuery(); 

以上就是存储过程的几种使用方式,在实际使用过程中,可能会有些许偏差……
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值