设为首页 收藏本站
查看: 781|回复: 0

[经验分享] Ibatis 调用Oracle返回Cursor的函数/过程

[复制链接]

尚未签到

发表于 2016-8-7 06:12:17 | 显示全部楼层 |阅读模式
为了方便我们经常需要函数/过程返回结果集时采用返回cursor的方式得到结果集,在ibatis以前版本中支持的不是很好,   
现在最新版本已经可以支持的很好了.   
一.下载最新ibatis包.   
二.最新的连接oracle 10g的驱动ojdbc(我这里用的是oracle 10g)   
三.下载最新的common包.   
示例如下:   
函数定义:   
CREATE OR REPLACE FUNCTION GetCurTest(   
     param1        in    varchar2;   
     param2          in    varchar2;   
)return SYS_REFCURSOR   
IS   
     outCursor SYS_REFCURSOR; --输出的游标   
BEGIN   
     open outCursor for   
           select ORGANCODE from testTable where col1 = GetCurTest.param1 and col2 = GetCurTest.param2;   
         return outCursor;   
END; 注意这里用的是SYS_REFCURSOR,在oracle10g里面提供的.   
ibatis中调用如下:   
<typeAlias alias="corp" type="com.wes.model.Corp" />  
<resultMap id="corp-map" class="corp">  
     <result property="corpNo" column="ORGANCODE" />  
</resultMap>  
<parameterMap id="test" class="java.util.HashMap" >   
     <parameter property="result" jdbcType="ORACLECURSOR" javaType="java.sql.ResultSet" mode="OUT" resultMap="corp-map" />  
     <parameter property="param1" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>   
     <parameter property="param2" jdbcType="Date" javaType="java.util.Date" mode="IN"/>   
</parameterMap>  
<procedure id="testCur" parameterMap="test">   
     {? = call GetCurTest(?, ?)}   
</procedure>java中调用如下:   
  String resource = "SqlMapConfig.xml";   
  SqlMapClient client = null;   
  try...{   
     Reader reader = Resources.getResourceAsReader(resource);   
     client = SqlMapClientBuilder.buildSqlMapClient(reader);   
     }catch (Throwable e)...{}   
Map p = new HashMap();   
p.put("param1","a");   
p.put("param2","b");   
client.queryForObject(mapid, p);   
List list = (List) p.get("result");   
if (list == null || list.size() == 0)   
    list = new ArrayList();   
return list;   
list存放的就是我们要的结果集.   
   
ibatis 调用存储过程 ibatis 调用存储过程   
4.Procedure   
procedure 元素支持存储过程。大部分存储过程要一些类似IN, INOUT 或者 OUT 的参数。所以,创建一个 <parameterMap> 元素并列出你要向存储过程传递的参数。只有当参数类型为OUT或者INOUT时parameterMap 对象才会被改变。   
   
<parameterMap id="swapParameters" class="map" >  
  <parameter property="contactId" jdbcType="INTEGER" javaType="java.lang.Integer" mode="IN"/>  
  <parameter property="firstName" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>   
  <parameter property="lastName" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>  
</parameterMap>  
   
<procedure id="swapContactName" parameterMap="swapParameters" >  
{call swap_contact_name (?, ?,?)}   
</procedure>  
   
你的代码一开始就要创建一个你要传递给存储过程的参数的 HashMap ,然后把它和你要执行的查询的名称一同传递给 sqlMap 。   
   
HashMap paramMap = new HashMap();   
paramMap.put("contactId", new Integer(1));   
paramMap.put("firstName", "Sunil");   
paramMap.put("lastName", "Patil");   
sqlMap.queryForObject("swapCustomerName", paramMap);   
--------------------------------------------------------------------------------------------------   
   
5.Calling an Oracle procedure function using Ibatis   
   
The ibatis documentation provides a sample on how to call a procedure, but how do you call a function in Oracle? The code sample shows it.   
   
<parameterMap id="getSomeFunction" class="java.util.Map" >   
<parameter property="question1" jdbcType="INTEGER" javaType="java.lang.String" mode="OUT"/>   
<parameter property="question2" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>   
<parameter property="question3" jdbcType="INTEGER" javaType="java.lang.String" mode="IN"/>   
<parameter property="question54" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>   
<parameter property="question5" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>   
</parameterMap>  
   
<procedure id="getSomeFunction" parameterMap="getSomeFunction">   
{? = call FNC_EXECUTE_SOME_FUNCTION(?, ?, ?, ?)}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-253930-1-1.html 上篇帖子: 关于Oracle 10g scott用户解锁的方法两则 下篇帖子: 如果解决oracle中id自增并发冲突问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表