> 데이터 베이스 > MySQL 튜토리얼 > mybatis는 어떻게 mysql 저장 프로시저를 호출하고 반환 값을 얻습니까?

mybatis는 어떻게 mysql 저장 프로시저를 호출하고 반환 값을 얻습니까?

王林
풀어 주다: 2023-05-27 09:01:30
앞으로
2074명이 탐색했습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿