存儲過程在小公司用的不多,但是如果業務比較復雜或者性能要求比較苛刻的時候存儲過程就派上用場了,ibatis的前期的一些版本貌似不支持存儲過程因此我選擇了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());
- }
- }
下面是執行結果
返回游標 可以直接用下面的方法
Map map = new HashMap(); map.put("jid", jid); userInfoMapper.getFriendList(map); //result 為在mybatis xml文件時 寫的返回結果名 List<UserInfo> list = (List<UserInfo>)map.get("result"); return list;