MYBATIS use procedure(oracle database)
2015-07-01 13:54
561 查看
1.无输入和输出参数的存储过程
我写了一个比较简单的,需要注意的是Oracle无参存储过程不能写括号
这里执行了2个操作,可能用过mybatis的人会迷惑执行的时候到底使用update标签呢还是delete标签,其实都行,我也试过select标签也是OK的,下面是部分的配置文件
2.带有输入和输出参数的存储过程
这里加入了if else的几个判断
下面顺便把我在命令行窗口执行的存储过程语句贴出来
执行过类似语句的时候可能看不到任何的输出,不要着急只需在命令行使用set serveroutput on;
看到结果了吧,下面使用mybatis来执行这个存储过程,下面是映射文件的写法
那怎么取得返回的内容呢,其实只要存储过程执行后map里就有值了,java代码大致如下
3.返回游标的存储过程
还有一种存储过程,它可以返回一个游标就类似一个集合这种
这种情况,在mybatis里就稍微有些不同了,此时jdbcType就是CURSOR,javaType则是ResultSet了,这里还可以把结果转成resultMap了,如下所示
调用存储过程的java代码:
?
我写了一个比较简单的,需要注意的是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 map = new HashMap(); map.put("jid", jid); Mapper.getFriendList(map); //result 为在mybatis xml文件时 写的返回结果名 List<UserInfo> list = (List<UserInfo>)map.get("result"); return list;
?
相关文章推荐
- Oracle之ORA-00972: identifier is too long
- oracle 数据库服务器CPU资源占用超高(75%)
- Linux系统(X64)安装Oracle11g完整安装图文教程另附基本操作
- Oracle:environment variable "PATH" does not exceed the recommended length
- oracle笔记一(sql语句方面)
- ORACLE触发器详解
- Oracle高级编程
- Oracle-属性查询
- oracle的一个比较回应的论坛,oracle数据库关闭和启动命令
- Oracle-锁表、解锁
- PL/SQL远程登录Oracle时遇到问题(一)
- MySQL与Oracle 差异比较之基本语法
- BUG Hunting:PeopleSoft-Application Designer登陆失败 oracle-01017
- 新的oracle学习与分享之路
- PL/SQL不配tnsnames.ora直接连接Oracle数据库的方法
- Talend 将Oracle中数据导入到hive中,根据系统时间设置hive分区字段
- 足球和oracle系列(3):oracle过程排名,世界杯第二回合战罢到来!
- Oracle中使用Entity Framework 6.x Code-First
- Oracle11g切换语言环境
- Oracle11g自动启动