#结束符号默认;, 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 ;
(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>
これは単純なストアド プロシージャ
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 サイトの他の関連記事を参照してください。