http://blog.sina.com.cn/s/blog_6f3ca78f01010pmj.html

iBatic调用与JAVA调用很类似,只是JAVA把参数的注册放到了类里面,而iBatis把参数的注册放到了XML配置文件里,下面两个例子,第一个是返回普通数据,第二个是返回游标。

1:返回普通数据

Map map = new HashMap();

map.put("username", "JACK");

sqlMapClient.queryForObject("pro_test",map);

System.out.println(map);

输出结果:

{o=NBA, ooo=1, oo=JACK, username=JACK}

<!--   存储过程 -->

<parameterMap class="hashmap" id="pro_map">

<parameter property="username" javaType="String" jdbcType="VARCHAR" mode="INOUT"/>

<parameter property="o" javaType="String" jdbcType="VARCHAR" mode="OUT"/>

<parameter property="ooo" javaType="java.lang.Integer" jdbcType="INTEGER"mode="OUT"/>

<parameter property="oo" javaType="String" jdbcType="VARCHAR" mode="OUT"/>

</parameterMap>

<procedure id="pro_test" parameterMap="pro_map">

{call user_account_proc(?,?,?,?)}

</procedure>

create or replace procedure user_account_proc

(

uname in out varchar,

ugroupname out varchar,

uid out number,

ugro out varchar

)

as

begin

select groupname,username,userid into ugroupname,ugro,uid from user_account where username = uname;

end;

2:返回一个游标

Map map1 = new HashMap();

sqlMapClient.queryForObject("pro_cursor",map1);

System.out.println(map1.get("backcursor"));

输出结果:

[

{userid=1, username=JACK, userpwd=BEIJING, groupname=NBA},

{userid=2, username=TOM, userpwd=SHANGHAI, groupname=NBA},

{userid=3, username=MARY, userpwd=SHANGHAI, groupname=IBM}

]

配置文件:

<resultMap class="hashmap" id="backmap">

<result property="userid" column="USERID"/>

<result property="username" column="USERNAME"/>

<result property="userpwd" column="USERPWD"/>

<result property="groupname" column="GROUPNAME"/>

</resultMap>

<parameterMap class="hashmap" id="pro_cursor_map">

<parameter property="backcursor" javaType="java.sql.ResultSet"

jdbcType="ORACLECURSOR" mode="OUT" resultMap="backmap"/>

</parameterMap>

<procedure id="pro_cursor" parameterMap="pro_cursor_map">

{call user_account_proc1(?)}

</procedure>

过程:

create or replace procedure user_account_proc1

(

my_cursor out sys_refcursor

)

as

begin

open my_cursor for select * from user_account;

end;

另:ibatis调用oracle的函数,存储过程的方法 IN 和OUT /游标

1、对于全部是in 类型的参数过程,采用下面的方法调用(ibatis版本是2.3)

比如过程:

    Procedure Flashback_Op(v_table_owner Varchar2,v_table_name Varchar2,v_FlashbackScn   Number,v_xid Varchar2,v_dbid number);

调用方法:

  <parameterMap id="tableDml_recycle" class="java.util.Map">
        <parameter property="owner" jdbcType="varchar"
             javaType="java.lang.String" mode="IN " />
         <parameter property="name" jdbcType="varchar"
            javaType="java.lang.String" mode="IN " />
         <parameter property="scn" jdbcType="NUMBER"
             javaType="java.math.BigDecimal" mode="IN " />
         <parameter property="dbId" jdbcType="NUMBER"
             javaType="java.math.BigDecimal" mode="IN " />
    </parameterMap>
   
    <procedure id="tableDml_zcRecycle" parameterMap="tableDml_recycle">  
        {call TassetREC.Flashback_Op(?,?,?,?,?)}  
    </procedure>

  2、对于返回类型是游标 (OUT)的函数,采用如下方式调用。

函数:

   Function GetFirstPageNumRows(v_where varchar2,v_dbid Number,v_Numrows varchar2,v_queryid varchar2) return sys_refcursor ;

   调用方式:

  <parameterMap id="searchParam" class="java.util.Map">
        <parameter property="result" jdbcType="ORACLECURSOR"
        javaType="java.sql.ResultSet" mode="OUT " resultMap="auditselect_resultList" />
       
        <parameter property="ipAddress"
            jdbcType="varchar" javaType="java.lang.String" mode="IN" />
        <parameter property="dbId" jdbcType="NUMBER"
            javaType="java.math.BigDecimal" mode="IN"/>
        <parameter property="countNumber" jdbcType="NUMBER"
            javaType="java.lang.Integer" mode="IN"/>
        <parameter property="clientId" jdbcType="VARCHAR2"
            javaType="java.lang.String" mode="IN"/>
    </parameterMap>

 <procedure id="firstPage" parameterMap="searchParam">  
        {? = call tlgadmin.GetFirstPageNumRows(?,?,?,?)}   (注意返回值在前面用?代表)
    </procedure>

 java代码这么取值:

  @SuppressWarnings("unchecked")
    public List getAuditSelectByPages(Map map) {
        getSqlMapClientTemplate().queryForList("firstPage", map);//调用
        List arryList = (ArrayList) map.get("result");//取值 
        return arryList;
    }

3、对于返回值为一般数据类型的函数:

函数:

  Function DeleteCommand(v_commandid Number,v_commandsetid Number default 0,v_dbid Number default 0) return Number ;

采用如下方式处理(把返回值当作出参来处理OUT):

  <parameterMap id="CommandDeleteById" class="java.util.Map">
        <parameter property="result" jdbcType="VARCHAR"
            javaType="java.lang.String" mode="OUT" />
        <parameter property="commandId" jdbcType="NUMBER"
            javaType="java.lang.Integer" mode="IN" />
        <parameter property="commandsetId" jdbcType="NUMBER"
            javaType="java.lang.Integer" mode="IN" />
        <parameter property="dbId" jdbcType="NUMBER"
            javaType="java.math.BigDecimal" mode="IN" />
    </parameterMap>

 <procedure id="Command_deleteById"
        parameterMap="CommandDeleteById">
        { ? = call truleadmin.DeleteCommand(?,?,?)}
    </procedure>

java代码

      this.getSqlMapClientTemplate().delete("Command_deleteById", map);
        String num = (String) map.get("result");
        return num;

ibatis调存储过程返回游标的更多相关文章

  1. oracle ibatis 存储过程 返回游标 嵌套表

    自己解决问题了 问题总结: 1.index by表不能存储在数据库中的type中,故选择嵌套表. 2.ibatis不支持oracle的复合数据类型的返回.(个人理解) 3.替代方案:用返回oracle ...

  2. mybatis 调用存储过程 返回游标 实例

    存储过程示例: create or replace procedure Fsp_Plan_CheckPrj(v_grantno varchar2, v_deptcode number, v_curso ...

  3. sqlserver 存储过程返回游标的处理

    创建表: create table tb1( id int , name ) ) ------------------------------------------------- 创建返回游标的存储 ...

  4. myBatIs.Net 调用Oracle 存储过程返回游标

    找了好久,网上也没示例,全是java的,没办法,后来看到一个网上别人写的例子. http://www.myfirm.cn/blog/article/Control/13.html 上面照套还是出错,我 ...

  5. Oracle存储过程返回游标实例详解

    复制代码 代码如下:CREATE OR REPLACE PROCEDURE PROCSENDEMAIL(P_TXT VARCHAR2, P_SUB VARCHAR2, P_SENDOR VARCHAR ...

  6. java 调用oracle 分页存储过程 返回游标数据集

    1.分页类 package org.zh.basic; /** * 页面类 * * @author keven * */ public class PageInfo { // 定义 private S ...

  7. Java和Ibatis调用存储过程并取得返回值详解

    Java和Ibatis调用存储过程并取得返回值详解 2011-07-19 17:33 jiandanfeng2 CSDN博客 字号:T | T 本文主要介绍了Java和Ibatis调用存储过程的方法, ...

  8. (转载)oracle 在一个存储过程中调用另一个返回游标的存储过程

    原文链接:http://www.jb51.net/article/20160.htm 实际项目当中经常需要在一个存储过程中调用另一个存储过程返回的游标,本文列举了两种情况讲述具体的操作方法. 第一种情 ...

  9. Java调用oracle存储过程通过游标返回临时表数据

    注:本文来源于 <  Java调用oracle存储过程通过游标返回临时表数据   > Java调用oracle存储过程通过游标返回临时表数据 项目开发过程中,不可避免的会用到存储过程返回结 ...

随机推荐

  1. HDU5647 DZY Loves Connecting 树形DP

    (先奉上jcvb大神的官方题解)BC 76 div 1 1002 对于每个结点i,统计出f[i]表示包含i的连通集有多少个,那么容易看出答案就是所有f[i]的和. 要计算f[i]是经典的树形DP问题. ...

  2. VS2010+WINDBG+VMWARE9.0和fatal error RC1106: invalid option: -ologo错误

    提供属性配置文件一份: http://pan.baidu.com/s/1iS1Ix <?xml version="1.0" encoding="utf-8" ...

  3. Unity 时间缩放状态下的特效播放

    时间缩放状态下,比如 Time.timeScale 缩小为 0 或者 0.000001 等极小值时,若想将特效的播放速度放大相同的倍数,即修改 ParticleSystem.playbackSpeed ...

  4. Java笔记(二十七)……IO流中 File文件对象与Properties类

    File类 用来将文件或目录封装成对象 方便对文件或目录信息进行处理 File对象可以作为参数传递给流进行操作 File类常用方法 创建 booleancreateNewFile():创建新文件,如果 ...

  5. 终端ls显示的配色方案

    打开~/.profile或者mac上的~/.bash_profile,加入: export CLICOLOR=1 export LSCOLORS=cxdxfxexbxegedabagacad 这是我的 ...

  6. POJ1502: MPI Maelstrom

    红果果的dijstra算法应用,这里采用邻接表存储图 小插曲:while(scanf("%d",&n))提交时内存超限,改成while(scanf("%d&quo ...

  7. Casio普通计算器编程

    用xelatex写了个奇怪的东西……欢乐向 PDF  http://files.cnblogs.com/htfy/calc.pdf TEX http://files.cnblogs.com/htfy/ ...

  8. Python自动安装第三方类库

    Python在使用过程中会用到大量的第三方库,逐一手工去下载.安装比较繁琐.可以配置第三方镜像源并使用pip进行自动安装.这里推荐选择豆瓣的镜像源:http://pypi.douban.com/sim ...

  9. 递归小demo(1-100的和)

    public class demo1 { public static void main(String[] args) { //初始值为100 int n = 100; //调用number方法,返回 ...

  10. lua 学习笔记(一)

    lua 中的方法: 1. type("test"): 返回数据类型 2.#"zhangsan": 返回字符串的长度 3.string.gsub("字符 ...