mybatis调用mysql存储过程(返回参数,单结果集,多结果集)
一、接收一个返回值
使用Map接收返回参数,output参数放在传入的param中
创建表
DROP TABLE IF EXISTS `demo`; CREATE TABLE `demo` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=32 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of demo -- ---------------------------- INSERT INTO `demo` VALUES ('1', '测试');
创建存储过程
DROP PROCEDURE IF EXISTS pro; CREATE PROCEDURE pro ( IN userId INT, OUT userCount INT ) BEGIN DECLARE user_name VARCHAR (64); SELECT NAME FROM demo WHERE id = userId INTO user_name; INSERT INTO demo (NAME) VALUES (user_name); SELECT COUNT(*) FROM demo INTO userCount; END;
mapper.xml
<select id="procedureTest" parameterMap="pm" statementType="CALLABLE"> CALL pro(#{userId,mode=IN},#{userCount,mode=OUT,jdbcType=INTEGER}); </select> <parameterMap id="pm" type="java.util.Map"> <parameter property="userId" jdbcType="INTEGER" mode="IN"></parameter> <parameter property="userCount" jdbcType="INTEGER" mode="OUT"></parameter> </parameterMap>
service
@Override public void procedureTest() { Map<String, Object> param = new HashMap<>(); param.put("userId", "1"); demoMapper.procedureTest(param); System.out.println("输出结果是:"+param.get("userCount")); }
输出结果
参数名不一定和存储过程一样,只和传参顺有关,使用下图配置同样可以获取结果
System.out.println("输出结果是:"+param.get("userCount_2"));
注意事项:
1、 存储过程的参数和名称无关,只和顺序有关系
2、 存储过程的output参数,只能通过传入的map获取
3、 存储过程返回的结果集可直接用返回的map接收
4、 存储过程的return结果需要使用?=call procName(?,?)的第一个参数接收,需要指定对应的mode为OUT类型
5、 存储过程对应的数据类型为枚举类型,需要使用大写,如VARCHAR
output是在存储过程中的参数的返回值(输出参数),而ReturnValue是存储过程返回的值(使用return关键字),一个存储过程可以有任意多个依靠参数返回的值,但只有一个ReturnValue。
存储过程主要分成三类:
1、返回记录集的存储过程:执行结果是一个记录集,例如,从数据库中检索出符合某一个或几个条件的记录。
2、返回数值得的存储过程(也可称为标量存储过程),其执行完后返回一个值,例如数据库中执行一个有返回值的函数或命令。
3、行为存储过程,用来实现数据库的某个功能,而没有返回值,例如在数据库中的更新和删除操作。
二、接收list结果集
使用list接收
@Override public void procedureTest() { Map<String, Object> param = new HashMap<>(); param.put("userId", "1"); List<?> list = demoMapper.procedureTest(param); System.out.println("输出结果是:" + param.get("userCount_2")); System.out.println("输出集合:" + list.size()); }
<select id="procedureTest" parameterMap="pm" statementType="CALLABLE" resultMap="rm"> CALL pro(#{userId,mode=IN},#{userCount_2,mode=OUT,jdbcType=INTEGER}); </select> <parameterMap id="pm" type="java.util.Map"> <parameter property="userId" jdbcType="INTEGER" mode="IN"></parameter> <parameter property="userCount_2" jdbcType="INTEGER" mode="OUT"></parameter> </parameterMap> <resultMap id="rm" type="com.csstj.srm.entity.procedureTestEntity"> <result column="id" property="id"></result> <result column="name" property="userName"></result> </resultMap>
三、返回多个结果集
四、第二种配置也可以
CALL s_generatePlan_new ( #{organizationId, mode=IN,jdbcType=VARCHAR}, #{gradeId, mode=IN,jdbcType=VARCHAR}, #{semesterId, mode=IN,jdbcType=VARCHAR}, #{className, mode=IN,jdbcType=VARCHAR}, #{employeeCode, mode=IN,jdbcType=VARCHAR}, #{courseName, mode=IN,jdbcType=VARCHAR}, #{classroomName, mode=IN,jdbcType=VARCHAR}, #{approverId, mode=IN,jdbcType=VARCHAR}, #{createBy, mode=IN,jdbcType=VARCHAR}, #{total,mode=OUT ,jdbcType=VARCHAR})
到此这篇关于mybatis调用mysql存储过程(返回参数,单结果集,多结果集)的文章就介绍到这了,更多相关mybatis调用mysql存储过程内容请搜索猪先飞以前的文章或继续浏览下面的相关文章希望大家以后多多支持猪先飞!
原文出处:https://blog.csdn.net/cs373616511/article/details/82890306
相关文章
- 这篇文章主要介绍了Mybatis Plus select 实现只查询部分字段的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01
- Create Procedure AtoC @ChangeMoney Money as Set Nocount ON Declare @String1 char(20) Declare @String2 char(30) ...2016-11-25
- 这篇文章主要介绍了MySQL性能监控软件Nagios的安装及配置教程,这里以CentOS操作系统为环境进行演示,需要的朋友可以参考下...2015-12-14
- 存储过程在数据库的应用中我们用到的非常的多了,下面我们来看一篇关于PHP操作MSSQL存储过程修改用户密码的例子,具体的如下所示。 mssql2008 存储过程 下面可以直接...2016-11-25
- 这篇文章主要介绍了解决Mybatis 大数据量的批量insert问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-09
- 这篇文章主要介绍了mybatis的Configuration详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-04
- 新版 Mysql 中加入了对 JSON Document 的支持,可以创建 JSON 类型的字段,并有一套函数支持对JSON的查询、修改等操作,下面就实际体验一下...2016-08-23
mybatis 返回Integer,Double,String等类型的数据操作
这篇文章主要介绍了mybatis 返回Integer,Double,String等类型的数据操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-25深入研究mysql中的varchar和limit(容易被忽略的知识)
为什么标题要起这个名字呢?commen sence指的是那些大家都应该知道的事情,但往往大家又会会略这些东西,或者对这些东西一知半解,今天我总结下自己在mysql中遇到的一些commen sense类型的问题。 ...2015-03-15- 这篇文章主要介绍了MySQL 字符串拆分操作(含分隔符的字符串截取),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-22
- 一、先说一下为什么要分表:当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,有可能会死在那儿了。分表的目的就在于此,减小数据库的负担,缩短查询时间。根据个人经验,mysql执行一个sql的过程如下:1...2014-05-31
- 具体详情请看下文小编给大家带来的知识点。同编写程序类似,存储过程中也有对应的条件判断,功能类似于if、switch。在MySql里面对应的是IF和CASE1、IF判断IF判断的格式是这样的:IF expression THEN commands [ELSEIF ex...2015-10-21
- 我们自己鼓捣mysql时,总免不了会遇到这个问题:插入中文字符出现乱码,虽然这是运维先给配好的环境,但是在自己机子上玩的时候咧,总得知道个一二吧,不然以后如何优雅的吹牛B。...2015-03-15
- 这几天在centos下装mysql,这里记录一下安装的过程,方便以后查阅Mysql5.5.37安装需要cmake,5.6版本开始都需要cmake来编译,5.5以后的版本应该也要装这个。安装cmake复制代码 代码如下: [root@local ~]# wget http://www.cm...2015-03-15
- 宿主机使用网线的时候,客户机在Bridged Adapter模式下,使用Atheros AR8131 PCI-E Gigabit Ethernet Controller上网没问题。 宿主机使用无线的时候,客户机在Bridged Adapter模式下,使用可选项里唯一一个WIFI选项,Microsoft Virtual Wifi Miniport Adapter也无法上网,故弃之。...2013-09-19
- 数据库中的数据删除会分为两种:物理删除 和 逻辑删除,接下来通过本文给大家介绍MyBatis-Plus的物理删除和逻辑删除使用场景分析,感兴趣的朋友一起看看吧...2021-09-25
Springboot如何使用mybatis实现拦截SQL分页
这篇文章主要介绍了Springboot使用mybatis实现拦截SQL分页,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-19- 首先要声明一点,大部分情况下,修改MySQL密码是需要有mysql里的root权限的...2013-09-11
- MySQL命令行导出数据库: 1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录 如我输入的命令行:cd C:/Program Files/MySQL/MySQL Server 4.1/bin (或者直接将windows的环境变量path中添加该目录) ...2013-09-26
- 这篇文章主要介绍了Mybatis执行update失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01