ホームページ  >  記事  >  データベース  >  mybatis はどのようにして mysql ストアド プロシージャを呼び出し、戻り値を取得しますか

mybatis はどのようにして mysql ストアド プロシージャを呼び出し、戻り値を取得しますか

王林
王林転載
2023-05-27 09:01:302017ブラウズ

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(&#39;${key1}&#39;, #{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
を追加します。

以上がmybatis はどのようにして mysql ストアド プロシージャを呼び出し、戻り値を取得しますかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。