Hibernate调用Oracle的存储过程

1.plsql 代码

一:
create Procedure proc()
begin
      select * from proctab;
end;

二:
create procedure  proc1(v_no number(4))
begin
    select * from proc1
    where id=v_no;
end;

2.Hibernate 存储过程调用的一种方法是,通过XML传统的映射方式去调用。

     -》存储过程映射和领域模型中的实体的对应关系

xml映射文件
<class name="com.test.User" table="proctab">     
        <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>

    -》Hibernate API 对存储过程的调用

Hibernate API code
Session ss= HibernateSessionFactory.getSession()     
List li=ss.getNamedQuery("getUser").list();     
ss.close();    
        Session ss= HibernateSessionFactory.getSession()  
        List li=ss.getNamedQuery("getUser").list();  
        ss.close();

    -》JDBC API 对存储过程的调用

jdbc 调用 
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();


    -》直接使用 Hibernate  createQuerySql调用存储过程

createSqlQuery
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();

   -》通过Hibernate API或者JDBC,API给存储过程传参

传参1
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 SQLQuery query = session.createSQLQuery("{Call proc(?)}");     
2 query.setString(0, 参数);     
3 List list =query.list();   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值