文档章节

mybatis相关--mybatis调用oracle存储过程

spinachgit
 spinachgit
发布于 07/31 21:51
字数 892
阅读 1
收藏 0

博客原文:使用mybatis执行oracle存储过程

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

本文转载自:https://blog.csdn.net/walkcode/article/details/9318039

spinachgit
粉丝 10
博文 268
码字总数 268958
作品 0
亳州
私信 提问
一个使用MyBatis调用Oracle数据库存储过程的例子

我的电脑操作系统版本为Win7旗舰版(ServicePack1),Oracle版本为Oracle11g 程序使用的jar包有:mybatis-3.2.2.jar、ojdbc14-10.2.0.2.0.jar 本例中使用的配置文件mybatis-config.xml,可以...

北风其凉
2016/03/26
261
0
mybatis项目中如何调用oracle存储过程(procedure)

如题。这篇博客讲诉你如何在在spring+springmvc+mybatis项目中调用oracle的存储过程(procedure),其实主要是mybatis下如何调用存储过程,不带参数的就不说了,就说说带参数的存储过程如传参...

奔跑的菜菜
2016/01/07
3.7K
1
mybatis调用oracle存储过程

博客原文:使用mybatis执行oracle存储过程 存储过程在小公司用的不多,但是如果业务比较复杂或者性能要求比较苛刻的时候存储过程就派上用场了,ibatis的前期的一些版本貌似不支持存储过程因此...

蛙牛
2014/07/30
17K
3
Oracle + Mybatis实现批量插入、更新和删除示例代码

前言 Mybatis是web工程开发中非常常用的数据持久化的框架,通过该框架,我们非常容易的进行数据库的增删改查。数据库连接进行事务提交的时候,需要耗费的资源比较多,如果需要插入更新的数据...

一看就喷亏的小猿
2018/11/22
291
0
Mybatis要如何捕捉存储过程执行异常的信息?

最近写的程序中发现存在如下的问题,当我用mybatis调用存储过程(数据库使用的是ORACLE),发现当过程执行存在异常,但是我事务任然提交了,目前的处理方法是根据过程中定义的返回标志来判断的,...

HansonReal
2017/02/27
678
4

没有更多内容

加载失败,请刷新页面

加载更多

正则表达式匹配

请实现一个函数用来匹配包括 '.' 和 '*' 的正则表达式。模式中的字符 '.' 表示任意一个字符,而 '*' 表示它前面的字符可以出现任意次(包含 0 次)。 在本题中,匹配是指字符串的所有字符匹配...

Garphy
今天
6
0
Laravel 5.1的多路由文件的配置

默认的路由配置文件只有一个, \app\Http\routes.php。 在同一个文件中写路由容易起冲突,文件会越来越大,就需要定义多个路由文件。 找到加载\app\Http\routes.php的文件, 打开\app\Provid...

mdoo
今天
5
0
Hibernate 5 开始使用指南前言

同时在面向对象软件和关系型数据库进行工作,可能会非常复杂和费时。数据在对象和数据库之间可能会不一致,然后导致开发成本会非常高。 Hibernate 是一个针对 Java 环境的对象关系映射(Obj...

honeymoose
今天
6
0
聊聊nacos ServiceManager的UpdatedServiceProcessor

序 本文主要研究一下nacos ServiceManager的UpdatedServiceProcessor ServiceManager.init nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/core/ServiceManager.java @Compone......

go4it
今天
7
0
正则表达式的使用(QQ格式的判断与空格的切割)

//正则表达式的使用 public static void main(String[] args) throws IOException, ClassNotFoundException { //test1("123456"); test2("-1 99 kk"); } /** * ......

zhengzhixiang
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部