mybatis調用mysql存儲過程并獲取返回值方式
mybatis調用mysql存儲過程并獲取返回值
1、mysql創(chuàng)建存儲過程
#結束符號默認;, delimiter $$語句表示結束符號變更為$$ delimiter $$ CREATE PROCEDURE `demo`(IN inStr VARCHAR(100), out ourStr VARCHAR(4000)) BEGIN SET ourStr = '01'; if (inStr == '02') then ?? ?set ourStr = '02'; end if; END$$ #結束符號修改 delimiter ;
2、mybatis調用
(1)注解方式
// key1和key2都是參數(shù)map中的key
// key1是需要傳入存儲過程的值
// key2是用于接收存儲過程返回的值,跟獲取自增主鍵類似
@Select("call demo('${key1}', #{key2, mode=OUT, jdbcType=VARCHAR})")
@Options(statementType = StatementType.CALLABLE)
String getDemoValue(Map<String, Object> map);(2)xml方式
?<select id="getDemoValue" resultType="java.lang.String" parameterType="java.util.Map" statementType="CALLABLE">
??? ?call demo('${key1}', #{key2, mode=OUT, jdbcType=VARCHAR})
?</select>mybatis調存儲過程遇到返回值null的坑
mybatis調存儲過程時返回值null
就簡單的一個存儲過程
BEGIN ? ?#SELECT COUNT(*) scount FROM test_user t WHERE t.user_sex=sex; ? ?SELECT user_name userName FROM test_user t WHERE t.user_sex=sex; END
然后在Mybatis Mapper配置文件中
?<!--存儲過程 ?輸入?yún)?shù)用Map -->
? <select id="queryCountBySexWithProcedure" statementType="CALLABLE" parameterType="java.util.Map" resultType="java.util.HashMap">
? ?? ?{
?? ? ??? ? CALL queryCountBySexWithProcedure(
?? ? ? ? ? ? ?#{sex,jdbcType=VARCHAR,mode=IN},
?? ? ? ??? ? ?#{userName,jdbcType=VARCHAR,mode=OUT}
?? ? ??? ? )
?? ?}
? </select>然后userName值null,這是為什么呢?在mapper.xml文件會做映射處理,而在存儲過程中下方標紅的屬性 user_name并不會自動映射到userName 值中,所以調用userName值一定返回null。
BEGIN ? ?#SELECT COUNT(*) scount FROM test_user t WHERE t.user_sex=sex; ? ?SELECT user_name userName FROM test_user t WHERE t.user_sex=sex; END
那怎么處理這樣問題呢?那就是加上INTO 關鍵字
BEGIN ?? ?#SELECT COUNT(*) scount FROM test_user t WHERE t.user_sex=sex; ? ? ? ? ?SELECT user_name INTO userName FROM test_user t WHERE t.user_sex=sex; END
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
springboot為異步任務規(guī)劃自定義線程池的實現(xiàn)
本文主要介紹了springboot為異步任務規(guī)劃自定義線程池,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-06-06
Springboot傳輸數(shù)據(jù)時日期格式化問題
這篇文章主要介紹了Springboot傳輸數(shù)據(jù)時日期格式化問題,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09
Java序列化JSON丟失精度問題的解決方法(修復Long類型太長)
這篇文章主要給大家介紹了關于Java序列化JSON丟失精度問題的解決方法,修復Long類型太長的相關資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2022-03-03
一行命令同時修改maven項目中多個module的版本號的方法
這篇文章主要介紹了一行命令同時修改maven項目中多個module的版本號的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06
Mybatis?Plus?中的LambdaQueryWrapper示例詳解
這篇文章主要介紹了Mybatis?Plus?中的LambdaQueryWrapper,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
java中Servlet監(jiān)聽器的工作原理及示例詳解
這篇文章主要介紹了java中Servlet監(jiān)聽器的工作原理及示例詳解。Servlet監(jiān)聽器用于監(jiān)聽一些重要事件的發(fā)生,監(jiān)聽器對象可以在事情發(fā)生前、發(fā)生后可以做一些必要的處理。感興趣的可以來了解一下2020-07-07
mybatis-plus的自動填充時間的問題(添加到數(shù)據(jù)庫的時間比當前時間多4個小時)
這篇文章主要介紹了mybatis-plus的自動填充時間的問題(添加到數(shù)據(jù)庫的時間比當前時間多4個小時),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09

