ibatis调存储过程返回游标
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调用Oracle存储过程返回自定义类型 在企业级应用开发中,尤其是在金融、保险等业务场景中,往往需要处理复杂的数据结构与逻辑。本文将深入探讨如何使用Ibatis框架来调用Oracle数据库中的存储过程,并实现...
在iBatis中,当存储过程返回一个游标时,你可以将其映射为一个Java List。为此,你需要在Java方法中声明一个List类型的参数,而在SQL映射文件中,使用`<resultMap>`定义一个结果集映射,然后在`<selectResult>`标签...
他在项目中运用了Spring、Ibatis等技术,结合Oracle的存储过程进行数据处理,如加班时长统计报表的生成,这体现了他对业务逻辑和数据库操作的综合运用能力。此外,他还熟悉Junit单元测试,确保代码质量,以及Quartz...
### 访问存储过程(或函数)通过IBATIS中的Procedure标签定义Statement 在IBATIS框架中,访问数据库中的存储过程或者函数是一项常见的需求。本文将深入探讨如何利用IBATIS提供的`procedure`标签来定义这样的操作,...
`ibatis`,全称为`MyBatis`,是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。在Java世界里,`ibatis`为解决繁琐的JDBC代码和手动处理结果集的问题提供了强大而灵活的解决方案。尤其在与Oracle这样...
2. **iBatis框架**:在iBatis框架中,持久化对象之间一对一的关联关系是通过`<one-to-one>`元素定义的。这允许在Java对象和数据库记录之间建立映射关系。正确答案是A。 3. **日期和时间函数**:在SQL查询中,`...
- **存储过程**: 是一种用户定义的SQL指令集合,旨在完成特定任务或针对特定表和其他对象的操作。用户可以直接调用这些存储过程来执行预定义的操作。 - **函数**: 相比之下,函数更侧重于接收输入参数并返回一个特定...
Oracle数据库开发是一个重要的领域,涉及数据存储、查询和管理等多个方面。在北语19春的《Oracle数据库开发》作业中,我们可以看到一系列与数据库管理相关的知识点。 首先,数据库的基本逻辑结构是表空间(B选项)...
存储过程是一种预编译的 SQL 代码块,可以在 Oracle 数据库中执行复杂的逻辑。基本语法结构如下: ```sql CREATE OR REPLACE PROCEDURE procedure_name (parameter1 IN type1, parameter2 OUT type2) AS -- 变量...