首頁 > 軟體

mybatis呼叫mysql儲存過程並獲取返回值方式

2022-08-24 18:04:19

mybatis呼叫mysql儲存過程並獲取返回值

1、mysql建立儲存過程

#結束符號預設;, 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都是引數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組態檔中

 <!--儲存過程  輸入引數用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

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com