MyBatis调用存储过程

本文详细介绍了如何使用MyBatis调用不同类型的Oracle存储过程,包括无输入输出参数、带有输入输出参数以及返回游标的存储过程。通过示例展示了配置文件和Java代码的实现方式,帮助理解MyBatis如何处理存储过程的执行与结果获取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.无输入和输出参数的存储过程

我写了一个比较简单的,需要注意的是Oracle无参存储过程不能写括号

CREATE OR REPLACE Procedure cascadeoperation

As

Begin

 Delete From teacher Where id=1;

 Update studentdetail Set address='宁波市海曙区' Where studentid=10;

End;


这里执行了2个操作,可能用过mybatis的人会迷惑执行的时候到底使用update标签呢还是delete标签,其实都行,我也试过select标签也是OK的,下面是部分的配置文件

<delete id="cascadeOperation" statementType="CALLABLE" >

   {call cascadeoperation}

</delete>


2.带有输入和输出参数的存储过程

,我这里加入了if else的几个判断

CREATE OR REPLACE Procedure queryTeacher(fid In Integer,Type In Varchar,Name Out Varchar)

As

Begin

If Type='1' then

Select Name Into Name From student Where id=fid;

Else if Type='2' Then

Select Name Into Name From teacher Where id=fid;

Else 

 Name:='错误';

End If;

End If;

End;


下面顺便把我在命令行窗口执行的存储过程语句贴出来

Declare

Name  Varchar2(50);

Begin

queryteacher(3,'2',Name);

DBMS_OUTPUT.put_line(Name);

End;

/


执行过类似语句的时候可能看不到任何的输出,不要着急只需在命令行使用set serveroutput on;

看到结果了吧,下面使用mybatis来执行这个存储过程,下面是映射文件的写法

<select id="queryTeacher" statementType="CALLABLE" parameterType="java.util.Map">

   {call queryTeacher(#{fid,mode=IN,jdbcType=INTEGER},#{type,mode=IN,jdbcType=VARCHAR},#{name,mode=OUT,jdbcType=VARCHAR})}

</select>


那怎么取得返回的内容呢,其实只要存储过程执行后map里就有值了,java代码大致如下

Map<String,Object> mm=new HashMap<String,Object>();

 mm.put("fid", 3);

 mm.put("type", 2);

 m.queryTeacher(mm);

 System.out.println(mm.get("name"));

 

 

3.返回游标的存储过程

还有一种存储过程,它可以返回一个游标就类似一个集合这种

CREATE OR REPLACE Procedure getTeacher(cur_arg out Sys_Refcursor)

As

begin

    open cur_arg for Select * From teacher;

End;


这种情况,在mybatis里就稍微有些不同了,此时jdbcType就是CURSOR,javaType则是ResultSet了,这里还可以把结果转成resultMap了,如下所示

<resultMap id="resultMap3" type="org.lxh.module.usefunction.info.Teacher">

<result property="address" column="address"/>

<result property="name" column="name"/>

<result property="id" column="id"/>

   </resultMap>

 

<select id="getAllTeacherInfo" statementType="CALLABLE" parameterType="java.util.Map" >

   {call GETTEACHER(#{result,jdbcType=CURSOR,mode=OUT,javaType=ResultSet, resultMap=resultMap3})}

</select>

 

这里的话Java代码就稍微复杂一些

Map<String, Object> map = new HashMap<String, Object>();

m.getAllTeacher(map);

Set<Map.Entry<String, Object>> set = map.entrySet();

for (Iterator<Map.Entry<String, Object>> it = set.iterator(); it

.hasNext();) {

Map.Entry<String, Object> entry = (Map.Entry<String, Object>) it

.next();

// System.out.println(entry.getKey() + "--->" +

// (Teacher)entry.getValue());

List<Teacher> t = (List<Teacher>) entry.getValue();

Iterator<Teacher> itera = t.iterator();

while (itera.hasNext()) {

Teacher tt = itera.next();

System.out.println(tt.getName() + "," + tt.getAddress());

}

 

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值