使用mybatis执行oracle存储过程
来源:互联网 发布:js判断字符串不等于 编辑:程序博客网 时间:2024/04/28 14:39
存储过程在小公司用的不多,但是如果业务比较复杂或者性能要求比较苛刻的时候存储过程就派上用场了,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;
- <delete id="cascadeOperation" statementType="CALLABLE" >
- {call cascadeoperation}
- </delete>
- 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<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了,如下所示
[html]
- <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;
0 0
- 使用mybatis执行oracle存储过程
- 使用mybatis执行oracle存储过程
- oracle执行存储过程
- oracle 存储过程执行
- mybatis 存储过程使用
- MYBATIS调用oracle存储过程
- mybatis调用oracle存储过程
- MyBatis调用Oracle存储过程
- Mybatis调用oracle 存储过程
- mybatis调用ORACLE存储过程
- springmvc MyBatis 调用Oracle存储过程,使用Map传递参数
- oracle中执行存储过程
- oracle中执行存储过程
- 定时执行Oracle存储过程
- oracle 定时执行存储过程
- Oracle存储过程执行权限 .
- ORACLE 定时执行存储过程
- Oracle定时执行存储过程
- MySQL ERROR 1064 (42000)
- 【Hadoop】ZooKeeper的简单理解
- luoguP2439教室利用(贪心,排序,dp)
- 第七届蓝桥杯有奖猜谜
- 关系型数据库工作原理-数据库整体框架(翻译自Coding-Geek文章)
- 使用mybatis执行oracle存储过程
- QLPreviewController 预览文件
- 基于okHttpUtils网络请求的基类抽取
- 值栈详解(ValueStack)
- ettercap,shank和bettercap利用BeEF进行中间人攻击(1)
- 215. Kth Largest Element in an Array
- TCP和UDP的区别
- 小白的windows cpu 下caffe学习笔记(1)mnist测试
- java this的关键字