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());

}

 

}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章