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执行存储过程我随后会把文章添上来。



返回游标  可以直接用下面的方法  上面原作者的写法 太麻烦了

?


1

2

3

4

5

6

        Map map = new HashMap();

        map.put("jid", jid);

        userInfoMapper.getFriendList(map);

        //result 为在mybatis xml文件时 写的返回结果名

        List<UserInfo> list = (List<UserInfo>)map.get("result");

        return list;

时间: 2024-12-23 10:18:25

mybatis调用oracle存储过程的相关文章

jdbc调用 oracle 存储过程操作

创建有参存储函数findEmpNameAndSal(编号),查询7902号员工的的姓名和月薪,[返回多个值,演示out的用法]当返回2个或多个值,必须使用out符号当返回1个值,就无需out符号 create or replace function findEmpNameAndSal(pempno in number,pename out varchar2) return numberas psal emp.sal%type;begin select ename,sal into pename,

C#调用 Oracle 存储过程样例代码

-- 建表CREATE TABLE sale_report (     sale_date DATE NOT NULL ,     sale_item VARCHAR(2) NOT NULL ,      sale_money DECIMAL(10,2) NOT NULL,      PRIMARY KEY(sale_date, sale_item)); -- 測试数据DECLAREv_begin_day DATE;v_end_day DATE;BEGIN v_begin_day := TO_D

在java中调用Oracle存储过程

在java中调用Oracle存储过程 本文介绍如何通过java来调用Oracle的存储过程 1. 编写存储过程 CREATE OR REPLACE PROCEDURE sp_pro3(sp_name VARCHAR2,sp_sal NUMBER ) IS BEGIN --根据用户名修改工资 UPDATE emp SET sal=sp_sal WHERE ename=sp_name; END; 引入jdbc6.jar,编写测试类Test.java package testOraclePro; im

asp.net调用oracle存储过程

oracle内的存储过程是通过游标返回结果集的 DataTable dt = new DataTable(); OracleParameter[] paras = new OracleParameter[5]; paras[0] = new OracleParameter("p_StartTime", OracleType.Char); paras[0].Value = StartTime; paras[1] = new OracleParameter("p_EndTime&

C#调用Oracle存储过程

C#调用Oracle存储过程的代码如下所示: 1 using System; 2 using System.Collections.Generic; 3 using System.Collections.ObjectModel; 4 using System.ComponentModel; 5 using System.Configuration; 6 using System.Data; 7 using System.Data.OracleClient; 8 using System.Draw

C#调用Oracle存储过程的方法

本文实例讲述了C#调用Oracle存储过程的方法.分享给大家供大家参考.具体实现方法如下: Oracle数据库代码如下: 代码如下: create or replace procedure proce_test(paramin in varchar2,paramout out varchar2,paraminout in out varchar2) as varparam varchar2(28); begin varparam:=paramin; paramout:=varparam|| pa

Mybatis调用PostgreSQL存储过程实现数组入参传递

注:本文来源于 < Mybatis调用PostgreSQL存储过程实现数组入参传递  > 前言 项目中用到了Mybatis调用PostgreSQL存储过程(自定义函数)相关操作,由于PostgreSQL自带数组类型,所以有一个自定义函数的入参就是一个int数组,形如: CREATE OR REPLACE FUNCTION "public"."func_arr_update"(ids _int4)... 1 如上所示,参数是一个int数组,Mybatis提

Mybatis调用Oracle中的存储过程和function

一.Mybatis调用存储过程 1 在数据库中创建以下的存储过程create or replace procedure pro_hello(p_user_name in varchar2,p_result out varchar2) isbegin  p_result := 'hello,' || p_user_name;end; 2 编写SQL映射文件mapper.xmlstatementType里的CALLABLE是标注此sql为存储过程.parameterType是标注要传的参数,看了一些

springmvc+mybatis 调用oacle 存储过程返回游标!

oracle存储过程如下: HB_SAVE_MSG.P_QUERY_QUESTION_OF_QTA PROCEDURE P_QUERY_QUESTION_OF_QTA ( v_PaperID IN NUMBER, v_myCursor out MYCURSOR, v_optCursor out MYCURSOR ) IS BEGIN OPEN v_myCursor FOR SELECT A.QUESTION_ID,A.CONTENT,A.QTYPE_ID FROM T_QUESTION A IN