1. 程式人生 > >mybatis呼叫oracle儲存過程

mybatis呼叫oracle儲存過程

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來執行這個儲存過程,下面是對映檔案的寫法

<selectid
="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了,如下所示

<resultMapid="resultMap3"type="org.bosssoft.domain.Teacher">
	<resultproperty="address"column="address"/>
	<resultproperty="name"column="name"/>
	<resultproperty="id"column="id"/>
</resultMap>
<selectid="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();
			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());
			}

		}

返回遊標  可以直接用下面的方法 

        Map map = new HashMap();
        map.put("jid", jid);
        userInfoMapper.getFriendList(map);
        //result 為在mybatis xml檔案時 寫的返回結果名
        List<UserInfo> list = (List<UserInfo>)map.get("result");
        return list;