`
chenhua_1984
  • 浏览: 1252184 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

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;

分享到:
评论
1 楼 Rooock 2009-04-03  
是不是写错了?
一开始有定义<parameterMap id="tableDml_recycle" class="java.util.Map">
后面调用的却用的是
<procedure id="tableDml_zcRecycle" parameterMap="tableDml_caozuo"> 

相关推荐

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

    本篇文章将详细探讨如何在iBatis中调用Oracle的函数和存储过程,尤其是处理IN和OUT参数以及游标的场景。 首先,我们需要了解iBatis的基本工作原理。iBatis是一个SQL映射框架,它允许开发者将SQL语句写在XML配置文件...

    ibatis调用oracle存储过程分页

    ibatis调用oracle存储过程分页

    ibatis调用oracle存储过程

    在IT领域,特别是数据库操作与Java开发中,利用ibatis框架调用Oracle存储过程是一个常见的需求,这不仅能够提升代码的执行效率,还能增强应用程序的安全性。本文将深入解析ibatis如何与Oracle数据库中的存储过程进行...

    ibatis调用oracle的函数,存储过程的方法

    Ibatis,一个轻量级的Java持久层框架,提供了与数据库交互的能力,包括调用这些Oracle的函数和存储过程。本篇文章将详细介绍如何在Ibatis中调用Oracle的函数和存储过程。 首先,理解基本概念: 1. **Oracle函数**...

    Ibatis调用Oracle存储过程返回自定义类型

    ### Ibatis调用Oracle存储过程返回自定义类型 在企业级应用开发中,尤其是在金融、保险等业务场景中,往往需要处理复杂的数据结构与逻辑。本文将深入探讨如何使用Ibatis框架来调用Oracle数据库中的存储过程,并实现...

    ibatis调存储过程返回游标

    本文将深入探讨如何使用iBatis调用存储过程并返回游标,这是一个在处理复杂数据库操作时常见的需求。 ### iBatis调用存储过程返回游标 #### 存储过程简介 存储过程是预先编译并存储在数据库中的SQL代码块,它可以...

    ibatIS调用存储过程

    ibatIS调用存储过程是数据库操作中常见的一种技术,特别是在复杂的业务逻辑处理或数据批量操作时,存储过程能够提供更高的效率和更好的性能。本文将深入探讨如何在ibatIS框架中调用存储过程,以及涉及到的相关知识点...

    ibatis调用存储过程介绍

    在Java开发中,使用iBATIS(现在称为MyBatis)作为持久层框架时,调用数据库的存储过程是一种常见的需求。本文将详细介绍如何使用iBATIS调用存储过程,并提供一个简单的示例来说明其过程。 首先,我们需要在数据库...

    iBatis调用存储过程

    iBatis调用存储过程

    ibatis调用存储过程.txt

    根据提供的文件信息,标题为“ibatis调用存储过程”,主要关注的是如何使用ibatis框架来调用数据库中的存储过程。下面将详细解释ibatis框架的基本概念、存储过程的概念以及如何在ibatis中配置和执行存储过程。 ### ...

    ibatis调用存储过程

    当我们需要调用数据库中的存储过程时,iBATIS也提供了一种简便的方法。本篇文章将详细介绍如何在iBATIS中调用存储过程,包括带参数和不带参数的存储过程,并通过一个具体的例子进行说明。 首先,存储过程是预编译的...

    Ibatis调用存储过程调用存储过程

    本文将围绕“Ibatis调用存储过程”这一主题展开讨论,旨在帮助读者理解并掌握在Ibatis中调用存储过程的方法。 #### 二、存储过程与Ibatis简介 ##### 2.1 存储过程简介 存储过程是一种在数据库中预先编译好的SQL...

    ibatis+oracle实例

    3. **存储过程调用**:Ibatis可以通过`&lt;select&gt;`、`&lt;procedure&gt;`元素调用Oracle的存储过程,增强业务逻辑的封装性。 4. **连接池管理**:Ibatis可以与各种连接池(如C3P0、Druid、HikariCP等)集成,提高数据库连接...

    ibatis连接oracle所需的jar包

    5. **调用Ibatis接口**:在Java代码中,通过SqlSession对象调用SQL映射文件中的方法执行数据库操作。例如: ```java SqlSession session = sqlSessionFactory.openSession(); User user = session.selectOne(...

    Ibatis.net+ oracle 简单事例

    对于Oracle,可能需要利用其特有的函数或特性,如PL/SQL存储过程、游标等。 3. **SQL映射接口**:在.NET 类中创建对应的接口,这个接口的方法对应XML文件中的SQL语句,实现业务逻辑与SQL的绑定。 4. **事务管理**...

    ibatis 读取oracle clob类型

    ibatis 读取oracle clob类型

    Ibatis+Oracle(含对应数据库sql) 源码

    【标题】"Ibatis+Oracle(含对应数据库sql) 源码" 是一个学习和实践Ibatis与Oracle数据库结合使用的资源包。这个资源对于初学者来说尤其有帮助,因为它包含了一个实际项目的源代码和相应的SQL脚本,使得学习者能够...

    Spring MVC+ibatis+oracle框架整合

    在Spring MVC和iBatis的整合中,Oracle作为后端数据存储,通过JDBC驱动与应用进行交互。 **整合过程** 1. **配置Spring MVC**: 首先,需要在Spring的配置文件中声明DispatcherServlet,定义视图解析器,以及配置...

Global site tag (gtag.js) - Google Analytics