mybatis调用mysql存储过程并获取返回值方式

2022-09-03 15:22:49 59 0
魁首哥

目录

  • myBATis调用mysql存储过程并获取返回值
    • 1、mysql创建存储过程
    • 2、mybatis调用
  • mybatis调存储过程遇到返回值null的坑
    • mybatiphps调存储过程时返回值null

mybatis调用mysql存储过程并获取返回值

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
www.cppcns.com set ourStr = '02';
end if;

END$$
#结束符号修改
delimiter ;

2、mybatis调用

(1)注解方式

// key1和key2都是参数map中的key
// key1是需要传入存储过程的值
// key2是用于接收存储过程返回的值,跟获取自增主键类似
@Select("callandroid 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 值中,所以调用uservqOfRxbName值一定返回null。

BEGIN
 #SELECT COUNT(*) scount FROM test_usphper 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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

收藏
分享
海报
0 条评论
59
上一篇:源码分析SpringMvc日志打印被忽略输出问题 下一篇:Spring boot 运用策略模式实现避免多次使用if的操作代码

本站已关闭游客评论,请登录或者注册后再评论吧~

忘记密码?

图形验证码