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

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

目录

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

1、mysql创建存储过程

2、mybatis调用

mybatis调存储过程遇到返回值null的坑

mybatis调存储过程时返回值null

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('${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 值中,所以调用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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持易知道(ezd.cc)。

推荐阅读

    mac怎么安装mysql| macbook怎么下载mysql

    mac怎么安装mysql| macbook怎么下载mysql,标签,学习python 不得不学习的就是数据库,那么在开始学习数据库之前,那么今天我们先说下怎么安装m

    MySQL更新更新页面1/4。

    MySQL更新更新页面1/4。,,插入和替换 插入和替换语句的功能是将新数据插入表中,这两个语句的语法相似,它们之间的主要区别是如何处理重复的

    mysql数据库启动失败

    mysql数据库启动失败,报错,非正常,1、原因 公司服务器故障,非正常停机导致数据库启动失败。 报错信息 [ [email protected] dmp]# /etc/ini

    mysql长整型是什么

    mysql长整型是什么,整型,数据类型,语法,用户,填充,版本,MySQL长整型是“BIGINT”,是MySQL中最常用的数据类型之一,其可以用来存储较大的整数值,与

    深入理解MySQL分区

    深入理解MySQL分区,查询,数据,列表,索引,操作,按键,MySQL数据库是一个开源的关系型数据库管理系统。在一些大型数据环境中,为了更好地管理数据、

    mysql 如何查询

    mysql 如何查询,查询,数据,语句,条件,选取,排序,MySQL是一款常用的关系型数据库管理系统,被广泛应用于各种网站和应用开发。在MySQL中查询数据是

    MySQL中怎么实现分页操作

    MySQL中怎么实现分页操作,数据,显示,偏移量,分页,查询,初始,一、 背景什么是分页,就是查询时候数据量太大,一次性返回所有查询结果既耗费网络资源

    mysql怎么连接数据库

    mysql怎么连接数据库,服务,启动,数据库,命令,登录,步骤,mysql连接数据库的方法:1、通过计算机管理方式或通过命令行方式执行“net start mysql”

    mysql 查询拼接

    mysql 查询拼接,函数,字段,字符串,查询,分隔符,连接,MySQL 查询拼接在使用 MySQL 进行查询时,有时需要将多个字段或多张表中的字段进行拼接,这时