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

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());}}

下面是执行结果

到这里存储过程已经差不多了,研究了好久才弄出来,其他的用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;

本文转自:http://my.oschina.net/lujianing/blog/296427

转载于:https://www.cnblogs.com/dreammyle/p/4550534.html

使用mybatis执行oracle存储过程相关推荐

  1. spring+springMvc+mybatis 调用oracle 存储过程

    最近在项目中遇到在mybatis中调用oracle存储过程的问题,网上各种查询,最终解决了问题,在我们项目中我只需要oracle 的存储过程返回一个字符串用来存入数据库作为表数据的主键, 接下来整理代 ...

  2. mybatis 调用 oracle 存储过程 select into 无记录时NO_DATA_FOUND异常处理分析

    mybatis 调用 oracle 存储过程 select into 无记录时NO_DATA_FOUND异常处理分析 参考文章: (1)mybatis 调用 oracle 存储过程 select in ...

  3. springboot+mybatis调用oracle存储过程

    1 存储过程参数为VARCHAR 代码逻辑:controller层定义实体类对象entity,并entity.set给存储过程的输入参数赋值,把赋值后的实体类通过service层传到dao层,然后通过 ...

  4. jdbc oracle存储过程,java jdbc 执行oracle存储过程

    java jdbc 执行oracle存储过程 发布时间:2020-07-12 08:25:32 来源:51CTO 阅读:188 作者:v512345 java代码 public Connection ...

  5. mybatis调用oracle存储过程

    有输入与输出参数的存储过程 oracle存储过程部分代码: create or replace procedure PT_copy_Shipment_One_Data( oldShipmentId i ...

  6. mybatis调用oracle过程,使用MyBatis调用Oracle存储过程

    一.Oracle存储过程 存储过程代码: create or replace procedure TEST_DEMO_PROC(param_name IN VARCHAR2, return_resul ...

  7. shell执行oracle存储过程,获得存储过程返回值

    From: http://www.flatws.cn/article/program/oracle/2011-06-27/32316.html 同事做一个小的etl调度,需要将存储过程执行情况进行返回 ...

  8. java 执行oracle 存储过程_oracle--在java中调用存储过程和存储函数

    在java中调用存储过程和存储函数 存储过程: 查询某个员工的姓名 月薪 职位: create or replace procedure queryempinfo(eno in number, pen ...

  9. c#执行oracle存储过程,C#中如何执行存储过程方法

    功能 :  根据调用的方法名称  反射动态调用  sql Command 的方法 代码如下: /// /// 存储过程的属性 /// ProcName 存储过程的名称 /// MethodName 执 ...

最新文章

  1. 三角量测(Triangulation)之再学习
  2. 大雁塔为什么七层_“大唐不夜城”广场旁边的千年古佛塔为何被叫“大雁塔”?...
  3. 在Java中有类似.NET的NotImplementedException吗?
  4. 埃隆·马斯克:比特币拥有着“极为出色”的结构,而纸质货币终将消失
  5. python 声明变量类型_python基础学习03数据类型和变量
  6. [工具]OFFICE插件管理工具-帮助更好地管理及使用电脑安装过的OFFICE插件
  7. C++基础知识(一)—— C++程序结构
  8. python用筛选法求解小于n的所有素数_用筛选法求解n以内的所有素数
  9. 雷军:哈哈哈哈哈哈 网友:小米9要来了!
  10. shell 免杀aspx_对于asp免杀webshell的一些总结
  11. 海康VisionMaster绘制图形到显示窗口
  12. 关于oppo和vivo这两年强势崛起的反思
  13. lisp 焊缝标注_基于ObjectARX的焊接符号标注系统开发
  14. 使用域控批量安装软件
  15. 浙江大学计算机科学与技术学院导师,浙江大学计算机科学与技术学院导师介绍:杨莹春...
  16. 苹果iPhone用户界面设计经验分享
  17. 使用Python API实现TRT版BN/hswish/Silu等算子
  18. 基于C语言实现的足球信息查询系统 课程报告+项目源码+演示PPT+项目截图
  19. C#输入三条边判断是否为三角形
  20. python-tkinter(7) 实现各种个样的撩妹鼠标拖尾

热门文章

  1. 在R中调用Java代码
  2. foreach遍历进阶_“枚举器“/GetEnumerator()方法
  3. android双击熄屏代码,Android响应双击屏幕事件
  4. php 构造 析构,php 构造方法和析构方法
  5. mysql语句使用_MySQL语句的使用
  6. 内核功能导致重启_红帽RHEL Linux 7.7正式版发布 支持内核实时修复技术无需重启...
  7. linux启动服务器ftp监听,Linux redhat6.5开启ftp服务
  8. vasp安装包_【问题集锦】VASPamp;MedeA 第十一期
  9. autorelease什么时候释放_乌龟的天性是什么,饲养中要释放龟的天性吗?
  10. 合并单元格两行_28 HTML5标签学习——table单元格的合并