#结束符号默认;, 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!