java的MybatisPlus調(diào)用儲存過程的返回數(shù)據(jù)問題
1.調(diào)用存儲過程
核心 statementType=”CALLABLE”
- mybatis調(diào)用存儲過程時需要指定statementType=”CALLABLE”,
- 這樣Mybatis內(nèi)部中調(diào)用sql語句時將采用CallableStatementHandler,
- 而CallableStatementHandler內(nèi)部將使用CallableStatement來調(diào)用存儲過程。
如果存儲過程是有參數(shù)的,需要指定mode屬性,可選值有IN、OUT和INOUT。
當mode為OUT或INOUT時必須同時指定jdbcType。
如下:
<select id="findName" statementType="CALLABLE" resultType="java.util.Map"> {call findName( #{name, mode=IN, jdbcType=VARCHAR}, #{email, mode=OUT, jdbcType=VARCHAR} )} </select>
或者
注意的問題:
每個#{}之間不能分行寫,因為翻譯過來會有空格,會報錯。
最好寫在一行吧,免得麻煩,就是不好看而已。
<!-- statementType 聲明指向的是什么類型,其中CALLABLE是執(zhí)行存儲過程和函數(shù)的 --> <select id="callProcedure" parameterType="map" statementType="CALLABLE"> {call PRO_GRAP(#{tabletag,mode=IN,jdbcType=VARCHAR},#{startdate,mode=IN,jdbcType=VARCHAR},#{enddate,mode=IN,jdbcType=VARCHAR})} </select>
2.測試調(diào)用
或者postman 請求,傳遞參數(shù)map
存儲過程調(diào)用完成后會把輸出參數(shù)賦值給入?yún)?,所以我們可以通過Map或?qū)嶓w類來接收輸出參數(shù),比如這里的name。
所以針對上述存儲過程調(diào)用,我們可以在Mapper接口中定義如下方法:
測試:
@Test public void callStatement() { Map<String, Object> map = new HashMap<String, Object>(); map.put("name", "zxn"); try { userEmailMapper.findName(map); } catch (Exception e) { e.printStackTrace(); } System.out.println(“execute=”+map.get("email")); }
/** * 參數(shù)和結(jié)果都在params中 * @param params */ void findName(Map<String, Object> params);
3.存儲過程示例
DROP PROCEDURE IF EXISTS findName; //如果存儲過程存在,先刪除掉存儲過程 CREATE PROCEDURE findName(IN `name` varchar(200),OUT `email_address` varchar(255)), SELECT `a`.`email` INTO email from user a WHERE `a`.`name`=`name`; END
4.驗證結(jié)果
輸出查詢出來的信息
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
使用IntelliJ IDEA2020.2.2 x64 新建java項目并且輸出Hello World
這篇文章主要介紹了使用IntelliJ IDEA2020.2.2 x64 新建java項目并且輸出Hello World,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11關于兩個BeanUtils.copyProperties()的用法及區(qū)別
這篇文章主要介紹了關于兩個BeanUtils.copyProperties()的用法及區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06Springboot Maven打包跳過測試的五種方式小結(jié)
本文主要介紹了Springboot Maven打包跳過測試的五種方式小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04Java Web開發(fā)之基于Session的購物商店實現(xiàn)方法
這篇文章主要介紹了Java Web開發(fā)之基于Session的購物商店實現(xiàn)方法,涉及Java針對session的操作及數(shù)據(jù)庫操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10