mybatis 调用mysql存储过程 带输出输入参数
http://lohasle.iteye.com/blog/1669879
存储过程都是一样的,只是根据自己的喜好,可以用MAP或者JAVABEAN传递参数。
- -- --------------------------------------------------------------------------------
- -- Routine DDL
- -- Note: comments before and after the routine body will not be stored by the server
- -- --------------------------------------------------------------------------------
- DELIMITER $$
- CREATE DEFINER=`root`@`localhost` PROCEDURE `selectCount`(
- IN pcsId int,
- IN drId int,
- IN partnerId int,
- IN customerId int,
- OUT pcsCount int,
- OUT drCount int
- )
- BEGIN
- select count(md.id) into @pcsC from mdm_device md
- left join mdm_device_security mds on mds.device_id = md.id
- where mds.device_rooted = pcsId
- and md.partner_id = partnerId and md.customer_id = customerId;
- set pcsCount = @pcsC;
- select count(md.id) into @drC from mdm_device md
- where md.managed_status = drId and DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(md.un_manage_date)
- and md.partner_id = partnerId and md.customer_id = customerId;
- set drCount = @drC;
- END
1.java调用传入MAP。获取通过MAP获取。
1.1 mapper文件写法
- <parameterMap type="map" id="homeVO">
- <parameter property="pcsId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="drId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="partnerId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="customerId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="pcsCount" jdbcType="INTEGER" mode="OUT"/>
- <parameter property="drCount" jdbcType="INTEGER" mode="OUT"/>
- </parameterMap>
- <select id="selectForHome" parameterMap="homeVO"
- statementType="CALLABLE">
- {call selectCount(
- ?,?,?,?,?,?
- )}
- </select>
1.2 java调用写法
- @Override
- public StringselectHomeCount(HomeVO home) throws Exception {
- Map<String, Object> map = new HashMap<String, Object>();
- map.put("pscId", 0);
- map.put("drId", 1);
- map.put("partnerId", 25);
- map.put("customerId", 50);
- map.put("isolation", 1);
- selectOne("Mapper.selectForHome", map);
- System.out.println(map.get("pcsCount"));
- return map.get("drCount");
- }
2.java调用传入javaBean。返回值通过javaBean属性获取
2.1 通过javabean传递参数 mapper写法
- <parameterMap type="com.polysaas.mdm.device.entity.HomeVO" id="home">
- <parameter property="pcsId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="drId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="partnerId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="customerId" jdbcType="INTEGER" mode="IN"/>
- <parameter property="pcsCount" jdbcType="INTEGER" mode="OUT"/>
- <parameter property="drCount" jdbcType="INTEGER" mode="OUT"/>
- </parameterMap>
javaBean可以通过两种来进行映射
- <resultMap type="com.polysaas.mdm.device.entity.HomeVO" id="home">
- <result column="partnerId" property="partnerId" jdbcType="INTEGER"/>
- <result column="customerId" property="customerId" jdbcType="INTEGER" />
- <result column="pcsId" property="pcsId" jdbcType="INTEGER" />
- <result column="drId" property="drId" jdbcType="INTEGER" />
- <result column="pcsCount" property="pcsCount" jdbcType="INTEGER" />
- <result column="drCount" property="drCount" jdbcType="INTEGER" />
- </resultMap>
- <select id="selectForHome2" parameterType="com.polysaas.mdm.device.entity.HomeVO"
- statementType="CALLABLE">
- {call selectCount(
- #{pcsId,jdbcType=INTEGER, mode=IN},
- #{drId, jdbcType=INTEGER,mode=IN},
- #{partnerId, jdbcType=INTEGER,mode=IN},
- #{customerId, jdbcType=INTEGER,mode=IN},
- #{pcsCount, jdbcType=INTEGER,mode=OUT},
- #{drCount, jdbcType=INTEGER,mode=OUT}
- )}
- </select>
2.2 通过javabean传递参数 java调用写法
- @Override
- public HomeVO selectHomeCount(HomeVO home) throws Exception {
- HomeVO vo = new HomeVO();
- vo.setPcsId(0);
- vo.setDrId(0);
- vo.setPartnerId(25);
- vo.setCustomerId(50);
- vo.setPcsCount(0);
- vo.setDrCount(0);
- selectOne("com.polysaas.mdm.device.mapper.MdmDeviceMapper.selectForHome2", vo);
- return vo;
- }
遇到异常很多。。记得的写下
1.通过javaBean的时候,#{pcsId, mode=IN, javaType=INTEGER},javaType这个属性是必须的。
2.使用javaBean传递。输出参数不需要初始值。个人喜好并建议使用javaBean,因为定义更清晰,封装性。
3.map可以用占位符问号,javaBean不可以。 会有异常 No value specified for parameter 1
4. 说不认识某个参数。。可能是没有创建存储过程,这个发生在多个库的时候
5. read Only 这个可能是事务控制只读。。我是因为存储过程有set 语句,而方法叫做selectAaaa()。
mybatis 调用mysql存储过程 带输出输入参数的更多相关文章
- java, mybatis, 调用mysql存储过程
Map<String, Object> bindinfo = new HashMap<String, Object>(); bindinfo.put(&q ...
- Mybatis调用Mysql存储过程
在我的后台系统中,今天需要使用到存储过程.存储过程还真没写过,今天就写了个存储过程.使用在后台中. 其实这个接口功能 是涉及几张表的修改,删除,新增的.就写个一个存储过程. 存储过程: ), ),) ...
- mybatis调用mysql的存储过程(procedure),实现查询操作(student表中的某个年级中的总人数 select (1) 或者 select (*))
step1:在mysql cmd中新建存储过程: drop procedure if exists queryCountByGrade ; delimiter // -- 定义存储过程结束符号为// ...
- spring mybatis 3.2调用mysql存储过程返回多结果集(完整、亲测、可用)
最近,有个开发提了个需求,希望中间件支持调用mysql存储过程时支持多结果集返回,因为某些原因我们使用了不少的存储过程,很多复杂的逻辑目前来看交互非常的多,所以从当前的现状来说,这个需求还是蛮合理的. ...
- MySQL存储过程带in和out参数
MySQL存储过程带in和out参数 最简单的例子: [html] mysql> DELIMITER $$ mysql> USE test $$ Database changed mysq ...
- MyBatis调用Oracle存储过程
MyBatis调用Oracle存储过程 1.无输入和输出参数的存储过程 2.带有输入和输出参数的存储过程 3.返回游标的存储过程 mybatis中的配置文件代码 <resultMap type= ...
- Mybatis调用PostgreSQL存储过程实现数组入参传递
注:本文来源于 < Mybatis调用PostgreSQL存储过程实现数组入参传递 > 前言 项目中用到了Mybatis调用PostgreSQL存储过程(自定义函数)相关操作,由于Pos ...
- PHP调用MYSQL存储过程实例
PHP调用MYSQL存储过程实例 标签: mysql存储phpsqlquerycmd 2010-09-26 11:10 11552人阅读 评论(3) 收藏 举报 实例一:无参的存储过程$conn = ...
- 调用MYSQL存储过程实例
PHP调用MYSQL存储过程实例 http://blog.csdn.net/ewing333/article/details/5906887 http://www.cnblogs.com/kkchen ...
随机推荐
- 10个热门IT证书
MCP (微软专家认证) CCNA (思科认证网络支持工程师) MCPD (微软认证开发专家) SCJP (SUN认证Java程序员) CISSP (信息系统安全认证专家) CompTIA A+认证 ...
- python实现websocket服务器,可以在web实时显示远程服务器日志
一.开始的话 使用python简单的实现websocket服务器,可以在浏览器上实时显示远程服务器的日志信息. 之前做了一个web版的发布系统,但没实现在线看日志,每次发布版本后,都需要登录到服务器上 ...
- gcc总结【基本用法】【选项】【动静态库】(转)
1.////////////////////////////////////////////////////////////////////////////////////////////////// ...
- C#位移运算符
代码如下: /// <summary> /// 位移运算符"<<"左位移运算符,">>"右位移运算符 /// 在进行位移运算 ...
- .NET Linq获取一个集合中的一个或多个属性,赋值到新的类对象
//得到自定义的list var list = schoolGradeClassModelList.Select(x => new DropDownListData() { DataTextFi ...
- ORACLE基本SQL语句-用户及建表篇
一.用户相关SQL语句 /*新建用户*/create user ; 说明:SA用户名,2013密码 /*授权connect,resource给用户sa*/grant connect,resource ...
- iOS在UITableViewController里使用UISearchDisplayController报错"[UISearchResultsTableView dequeueReusableCellWithIdentifier:forIndexPath:]"
出现如下错误: 2016-02-13 22:09:22.318 Test[2757:192106] *** Assertion failure in -[UISearchResultsTableVie ...
- OpenGL ES 2.0 顶点着色器的妙用
1.飘扬的旗帜(水面起伏) 基本原理 绘制一帧画面时由顶点着色器根据一定的规则变换各个顶点的位置,即可得到旗帜迎风飘扬的效果. 为了使旗帜的飘动过程比较平滑,采用基于正弦曲线的顶点位置变换规则.
- uva 10894 - Save Hridoy
#include <iostream> #include <string> #include <cstring> #include <cmath> us ...
- NodeJs简单七行爬虫--爬取自己Qzone的说说并存入数据库
没有那么难的,嘿嘿,说起来呢其实挺简单的,或者不能叫爬虫,只需要将自己的数据加载到程序里再进行解析就可以了,如果说你的Qzone是向所有人开放的,那么就有一个JSONP的接口,这么说来就简单了,也就不 ...