博客原文:使用mybatis執行oracle存儲過程
html
存儲過程在小公司用的很少,可是若是業務比較複雜或者性能要求比較苛刻的時候存儲過程就派上用場了,ibatis的前期的一些版本貌似不支持存儲過程所以我選擇了mybatis來作實驗。java
1.無輸入和輸出參數的存儲過程sql
我寫了一個比較簡單的,須要注意的是Oracle無參存儲過程不能寫括號mybatis
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的,下面是部分的配置文件oracle
<delete id="cascadeOperation" statementType="CALLABLE" > {call cascadeoperation} </delete>
2.帶有輸入和輸出參數的存儲過程app
,我這裏加入了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;
下面順便把我在命令行窗口執行的存儲過程語句貼出來spa
Declare Name Varchar2(50); Begin queryteacher(3,'2',Name); DBMS_OUTPUT.put_line(Name); End; /
執行過相似語句的時候可能看不到任何的輸出,不要着急只需在命令行使用set serveroutput on;.net
看到結果了吧,下面使用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執行存儲過程我隨後會把文章添上來。
返回遊標 能夠直接用下面的方法 上面原做者的寫法 太麻煩了
Map map = new HashMap(); map.put("jid", jid); userInfoMapper.getFriendList(map); //result 爲在mybatis xml文件時 寫的返回結果名 List<UserInfo> list = (List<UserInfo>)map.get("result"); return list;