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

网友投稿 644 2023-07-07

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

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方式

登录后复制

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

登录后复制

然后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登录后复制

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MySQL日期及时间字段怎么查询
下一篇:Windows Server 2012下如何安装MYSQL5.7.24
相关文章