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

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

1、mysql创建存储过程

#结束符号默认;, delimiter $$语句表示结束符号变更为$$delimiter $$CREATE PROCEDURE `demo`(IN inStr VARCHAR(100), out ourStr VARCHAR(4000))BEGINSET 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 map);

(2)xml方式

      call demo('${key1}', #{key2, mode=OUT, jdbcType=VARCHAR}) 

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配置文件中

存了个图 存了个图

视频图片解析/字幕/剪辑,视频高清保存/图片源图提取

存了个图 17 查看详情 存了个图

         {           CALL queryCountBySexWithProcedure(              #{sex,jdbcType=VARCHAR,mode=IN},              #{userName,jdbcType=VARCHAR,mode=OUT}           )    }  

然后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存储过程并获取返回值的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/271499.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 12:32:39
下一篇 2025年11月4日 12:35:35

相关推荐

发表回复

登录后才能评论
关注微信