使用mybatis执行oracle存储过程

存储过程在小公司用的不多,但是如果业务比较复杂或者性能要求比较苛刻的时候存储过程就派上用场了,ibatis的前期的一些版本貌似不支持存储过程因此我选择了mybatis来做实验。

1.无输入和输出参数的存储过程,我写了一个比较简单的,需要注意的是Oracle无参存储过程不能写括号

  1. CREATE OR REPLACE Procedure cascadeoperation  
  2. As  
  3. Begin  
  4.  Delete From teacher Where id=1;  
  5.  Update studentdetail Set address='宁波市海曙区' Where studentid=10;  
  6. End;  
这里执行了2个操作,可能用过mybatis的人会迷惑执行的时候到底使用update标签呢还是delete标签,其实都行,我也试过select标签也是OK的,下面是部分的配置文件

  1. <delete id="cascadeOperation" statementType="CALLABLE" >  
  2.        {call cascadeoperation}  
  3.     </delete>  
2.带有输入和输出参数的存储过程,我这里加入了if else的几个判断

  1. CREATE OR REPLACE Procedure queryTeacher(fid In Integer,Type In Varchar,Name Out Varchar)  
  2. As  
  3. Begin  
  4. If Type='1' then  
  5. Select Name Into Name From student Where id=fid;  
  6. Else if Type='2' Then  
  7. Select Name Into Name From teacher Where id=fid;  
  8. Else   
  9.  Name:='错误';  
  10. End If;  
  11. End If;  
  12. End;  
下面顺便把我在命令行窗口执行的存储过程语句贴出来

  1. Declare  
  2. Name  Varchar2(50);  
  3. Begin  
  4. queryteacher(3,'2',Name);  
  5. DBMS_OUTPUT.put_line(Name);  
  6. End;  
  7. /  

Declare
Name  Varchar2(50);
Begin
queryteacher(3,'2',Name);
DBMS_OUTPUT.put_line(Name);
End;
/

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


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

  1. <select id="queryTeacher" statementType="CALLABLE" parameterType="java.util.Map">  
  2.        {call queryTeacher(#{fid,mode=IN,jdbcType=INTEGER},#{type,mode=IN,jdbcType=VARCHAR},#{name,mode=OUT,jdbcType=VARCHAR})}  
  3.     </select>  
那怎么取得返回的内容呢,其实只要存储过程执行后map里就有值了,java代码大致如下

  1. Map<String,Object> mm=new HashMap<String,Object>();  
  2. mm.put("fid"3);  
  3. mm.put("type"2);  
  4. m.queryTeacher(mm);  
  5. 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了,如下所示

[html] 
  1. <resultMap id="resultMap3" type="org.lxh.module.usefunction.info.Teacher">  
  2. <result property="address" column="address"/>  
  3. <result property="name" column="name"/>  
  4. <result property="id" column="id"/>  
  5.   </resultMap>  
  1. <select id="getAllTeacherInfo" statementType="CALLABLE" parameterType="java.util.Map" >  
  2.        {call GETTEACHER(#{result,jdbcType=CURSOR,mode=OUT,javaType=ResultSetresultMap=resultMap3})}  
  3.     </select>  

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

  1. Map<String, Object> map = new HashMap<String, Object>();  
  2.         m.getAllTeacher(map);  
  3.         Set<Map.Entry<String, Object>> set = map.entrySet();  
  4.         for (Iterator<Map.Entry<String, Object>> it = set.iterator(); it  
  5.                 .hasNext();) {  
  6.             Map.Entry<String, Object> entry = (Map.Entry<String, Object>) it  
  7.                     .next();  
  8.             // System.out.println(entry.getKey() + "--->" +  
  9.             // (Teacher)entry.getValue());  
  10.             List<Teacher> t = (List<Teacher>) entry.getValue();  
  11.             Iterator<Teacher> itera = t.iterator();  
  12.             while (itera.hasNext()) {  
  13.                 Teacher tt = itera.next();  
  14.                 System.out.println(tt.getName() + "," + tt.getAddress());  
  15.             }  
  16.   
  17.         }  

下面是执行结果


到这里存储过程已经差不多了,研究了好久才弄出来,其他的用jdbc执行存储过程我随后会把文章添上来。奋斗


返回游标  可以直接用下面的方法  上面原作者的写法 太麻烦了

        Map map = new HashMap();
        map.put("jid", jid);
        userInfoMapper.getFriendList(map);
        //result 为在mybatis xml文件时 写的返回结果名
        List<UserInfo> list = (List<UserInfo>)map.get("result");
        return list;



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值