mybatis中如何調(diào)用oracle存儲過程

今天就跟大家聊聊有關(guān)mybatis中如何調(diào)用oracle存儲過程,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)公司專注于企業(yè)全網(wǎng)整合營銷推廣、網(wǎng)站重做改版、固原網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)電子商務(wù)商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為固原等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

1.無輸入和輸出參數(shù)的存儲過程

我寫了一個比較簡單的,需要注意的是Oracle無參存儲過程不能寫括號

CREATE OR REPLACE Procedure cascadeoperation
As
Begin
 Delete From teacher Where id=1;
 Update studentdetail Set address='寧波市海曙區(qū)' Where studentid=10;
End;

這里執(zhí)行了2個操作,可能用過mybatis的人會迷惑執(zhí)行的時候到底使用update標(biāo)簽?zāi)剡€是delete標(biāo)簽,其實(shí)都行,我也試過select標(biāo)簽也是OK的,下面是部分的配置文件

<delete id="cascadeOperation" statementType="CALLABLE" >
	   {call cascadeoperation}
	</delete>

2.帶有輸入和輸出參數(shù)的存儲過程

,我這里加入了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;

下面順便把我在命令行窗口執(zhí)行的存儲過程語句貼出來

Declare
Name  Varchar2(50);
Begin
queryteacher(3,'2',Name);
DBMS_OUTPUT.put_line(Name);
End;
/

執(zhí)行過類似語句的時候可能看不到任何的輸出,不要著急只需在命令行使用set serveroutput on;

看到結(jié)果了吧,下面使用mybatis來執(zhí)行這個存儲過程,下面是映射文件的寫法

<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í)只要存儲過程執(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"));

3.返回游標(biāo)的存儲過程

還有一種存儲過程,它可以返回一個游標(biāo)就類似一個集合這種

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了,這里還可以把結(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)  可以直接用下面的方法  上面原作者的寫法 太麻煩了

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

看完上述內(nèi)容,你們對mybatis中如何調(diào)用oracle存儲過程有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

當(dāng)前文章:mybatis中如何調(diào)用oracle存儲過程
分享地址:http://muchs.cn/article44/pphsee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供、定制開發(fā)品牌網(wǎng)站制作、企業(yè)建站、網(wǎng)站制作建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)