今天就跟大家聊聊有關(guān)mybatis中如何調(diào)用oracle存儲(chǔ)過(guò)程,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
我寫(xiě)了一個(gè)比較簡(jiǎn)單的,需要注意的是Oracle無(wú)參存儲(chǔ)過(guò)程不能寫(xiě)括號(hào)
CREATE OR REPLACE Procedure cascadeoperation As Begin Delete From teacher Where id=1; Update studentdetail Set address='寧波市海曙區(qū)' Where studentid=10; End;
這里執(zhí)行了2個(gè)操作,可能用過(guò)mybatis的人會(huì)迷惑執(zhí)行的時(shí)候到底使用update標(biāo)簽?zāi)剡€是delete標(biāo)簽,其實(shí)都行,我也試過(guò)select標(biāo)簽也是OK的,下面是部分的配置文件
<delete id="cascadeOperation" statementType="CALLABLE" > {call cascadeoperation} </delete>
,我這里加入了if else的幾個(gè)判斷
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:='錯(cuò)誤'; End If; End If; End;
下面順便把我在命令行窗口執(zhí)行的存儲(chǔ)過(guò)程語(yǔ)句貼出來(lái)
Declare Name Varchar2(50); Begin queryteacher(3,'2',Name); DBMS_OUTPUT.put_line(Name); End; /
執(zhí)行過(guò)類似語(yǔ)句的時(shí)候可能看不到任何的輸出,不要著急只需在命令行使用set serveroutput on;
看到結(jié)果了吧,下面使用mybatis來(lái)執(zhí)行這個(gè)存儲(chǔ)過(guò)程,下面是映射文件的寫(xiě)法
<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>
那怎么取得返回的內(nèi)容呢,其實(shí)只要存儲(chǔ)過(guò)程執(zhí)行后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"));
還有一種存儲(chǔ)過(guò)程,它可以返回一個(gè)游標(biāo)就類似一個(gè)集合這種
CREATE OR REPLACE Procedure getTeacher(cur_arg out Sys_Refcursor) As begin open cur_arg for Select * From teacher; End;
這種情況,在mybatis里就稍微有些不同了,此時(shí)jdbcType就是CURSOR,javaType則是ResultSet了,這里還可以把結(jié)果轉(zhuǎn)成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代碼就稍微復(fù)雜一些
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()); } }
返回游標(biāo) 可以直接用下面的方法 上面原作者的寫(xiě)法 太麻煩了
Map map = new HashMap(); map.put("jid", jid); userInfoMapper.getFriendList(map); //result 為在mybatis xml文件時(shí) 寫(xiě)的返回結(jié)果名 List<UserInfo> list = (List<UserInfo>)map.get("result"); return list;
看完上述內(nèi)容,你們對(duì)mybatis中如何調(diào)用oracle存儲(chǔ)過(guò)程有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。