存储过程在小公司用的不多,但是如果业务比较复杂或者性能要求比较苛刻的时候存储过程就派上用场了,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. /

执行过类似语句的时候可能看不到任何的输出,不要着急只需在命令行使用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.还有一种存储过程,它可以返回一个游标就类似一个集合这种

  1. CREATE OR REPLACE Procedure getTeacher(cur_arg out Sys_Refcursor)
  2. As
  3. begin
  4. open cur_arg for Select * From teacher;
  5. End;

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

  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=ResultSet, resultMap=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. }

下面是执行结果

返回游标  可以直接用下面的方法

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

mybatis调用存储过程 无参、带有输入输出参数,输出游标类型的 存储的更多相关文章

  1. MyBatis之四:调用存储过程含分页、输入输出参数

    在前面分别讲解了通过mybatis执行简单的增删改,多表联合查询,那么自然不能缺少存储过程调用,而且还带分页功能. 注意:表结构参见上篇讲解联合查询的表. 一.查询某班级以及该班级下面所有学生的记录 ...

  2. ADO.NET访问SQL Server调用存储过程带回参

    1,ADO.NET访问SQL Server调用存储过程带回参 2,DatabaseDesign  use northwind go --存储过程1 --插入一条商品 productname=芹菜 un ...

  3. 使用mybatis调用存储过程(注解形式和配置文件形式)

    最近在看资料中涉及到mybatis,突然想到mysql中的视图.存储过程.函数.现将在使用mybatis调用mysql的存储过程使用总结下: 使用的环境:mybatis3.4.6,mysql 5.6, ...

  4. MyBatis基础:MyBatis调用存储过程(6)

    1. 存储过程准备 CREATE PROCEDURE sp_task ( IN userId INT ) BEGIN SELECT * FROM task WHERE user_id = userId ...

  5. Java子类初始化调用父类无参构造

    实在是服了自己,子类初始化调用父类无参构造这种初学者都应该知道的事,我给忘了. 记得当初看书的时候各种概念抄在笔记本上,再上机实践,以为一辈子都不会忘,还是给忘了. 这件事说明了两个问题: 1.我没有 ...

  6. Mybatis调用存储过程报错

    Mybatis调用存储过程 贴码 123456 Error querying database. Cause: java.sql.SQLException: User does not have ac ...

  7. Mybatis 调用存储过程,使用Map进行输入输出参数的传递

    做个记录,以备后用 java代码: public String texuChange() throws Exception {        try {                         ...

  8. MyBatis调用存储过程,含有返回结果集、return参数和output参数

    Ibatis是我们经常使用的O/R映射框架,mybats是ibatis被Google收购后重新命名的一个工程,当然也做了大量的升级.而调用存储过程也是一次额C/S架构模式下经常使用的手段,我们知道,i ...

  9. 关于用mybatis调用存储过程时的入参和出参的传递方法

    一.问题描述 a)         目前调用读的存储过程的接口定义一般是:void  ReadDatalogs(Map<String,Object> map);,入参和出参都在这个map里 ...

随机推荐

  1. java学习笔记之泛型

    "泛型"这个术语的意思就是:"使用与许多许多的类型".泛型在编程语言中出现时,其最初的目的是希望类或方法能够具备最广泛的表达能力.如何做到这一点呢,正是通过解耦 ...

  2. BZOJ 1221: [HNOI2001] 软件开发

    1221: [HNOI2001] 软件开发 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1428  Solved: 791[Submit][Stat ...

  3. Linux CentOS6.x ip设置(网卡设置)

    修改IP永久生效按以下方法vi /etc/sysconfig/network-scripts/ifcfg-eth0(eth0,第一块网卡,如果是第二块则为eth1)按如下修改ip: DEVICE=et ...

  4. RabbitMQ 集群+负载均衡

    负载均衡 集群的配置已经搭建好了,代码也成功跑通,成功做到了高可用,但是我们的程序连接节点并不会管哪个服务器在忙.哪个服务器空闲,完全看心情想连谁就连谁.而且代码中要把每个ip的节点都手动的写出来 , ...

  5. Java开发环境搭建——Idea开发环境

    Idea版本选择由于公司使用JDK7,所以我选择安装Version 2016.1.4(手动安装试验出来的,最新版的2016.1.4启动时提示需要安装JDK8)下载 其实可以安装多个版本的JDK,然后指 ...

  6. Netty 系列之 Netty 高性能之道

    1. 背景 1.1. 惊人的性能数据 最近一个圈内朋友通过私信告诉我,通过使用 Netty4 + Thrift 压缩二进制编解码技术,他们实现了 10 W TPS(1 K 的复杂 POJO 对象)的跨 ...

  7. 【总结】.Net面试题集锦(一)

    一.背景 最近一直在准备面试,收到的面试邀请邮件里还有面试题,真是要当面霸的节奏,不过看看也好,一方面能够锻炼锻炼生锈的脑子,查缺补漏一下,另一方面,万一靠这几个面试题拿到offer呢,哈哈.开个玩笑 ...

  8. selenium 定位元素

    一.单个元素的定位方式: By.className(className))By.cssSelector(selector)By.id(id)By.linkText(linkText)By.name(n ...

  9. jQuery选择器总结

    jQuery 的选择器可谓之强大无比,这里简单地总结一下常用的元素查找方法   $("#myELement")    选择id值等于myElement的元素,id值不能重复在文档中 ...

  10. Django基础,Day6 - 单元测试tests

    在django项目app目录下,有个tests.py,我们通常可以直接在这文件中写我们的单元测试代码. test for a model 根据前面章节的操作步骤下来,在Question Model中有 ...