http://lohasle.iteye.com/blog/1669879

存储过程都是一样的,只是根据自己的喜好,可以用MAP或者JAVABEAN传递参数。

  1. -- --------------------------------------------------------------------------------
  2. -- Routine DDL
  3. -- Note: comments before and after the routine body will not be stored by the server
  4. -- --------------------------------------------------------------------------------
  5. DELIMITER $$
  6. CREATE DEFINER=`root`@`localhost` PROCEDURE `selectCount`(
  7. IN pcsId int,
  8. IN drId int,
  9. IN partnerId int,
  10. IN customerId int,
  11. OUT pcsCount int,
  12. OUT drCount int
  13. )
  14. BEGIN
  15. select count(md.id) into @pcsC from mdm_device md
  16. left join mdm_device_security mds on mds.device_id = md.id
  17. where mds.device_rooted = pcsId
  18. and md.partner_id = partnerId and md.customer_id = customerId;
  19. set pcsCount = @pcsC;
  20. select count(md.id) into @drC from mdm_device md
  21. where md.managed_status = drId and  DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(md.un_manage_date)
  22. and md.partner_id = partnerId and md.customer_id = customerId;
  23. set drCount = @drC;
  24. END

1.java调用传入MAP。获取通过MAP获取。

1.1 mapper文件写法

  1. <parameterMap type="map" id="homeVO">
  2. <parameter property="pcsId" jdbcType="INTEGER" mode="IN"/>
  3. <parameter property="drId" jdbcType="INTEGER" mode="IN"/>
  4. <parameter property="partnerId" jdbcType="INTEGER" mode="IN"/>
  5. <parameter property="customerId" jdbcType="INTEGER" mode="IN"/>
  6. <parameter property="pcsCount" jdbcType="INTEGER" mode="OUT"/>
  7. <parameter property="drCount" jdbcType="INTEGER" mode="OUT"/>
  8. </parameterMap>
  9. <select id="selectForHome" parameterMap="homeVO"
  10. statementType="CALLABLE">
  11. {call selectCount(
  12. ?,?,?,?,?,?
  13. )}
  14. </select>

1.2 java调用写法

  1. @Override
  2. public StringselectHomeCount(HomeVO home) throws Exception {
  3. Map<String, Object> map = new HashMap<String, Object>();
  4. map.put("pscId", 0);
  5. map.put("drId", 1);
  6. map.put("partnerId", 25);
  7. map.put("customerId", 50);
  8. map.put("isolation", 1);
  9. selectOne("Mapper.selectForHome", map);
  10. System.out.println(map.get("pcsCount"));
  11. return map.get("drCount");
  12. }

2.java调用传入javaBean。返回值通过javaBean属性获取

2.1 通过javabean传递参数  mapper写法

  1. <parameterMap type="com.polysaas.mdm.device.entity.HomeVO" id="home">
  2. <parameter property="pcsId" jdbcType="INTEGER" mode="IN"/>
  3. <parameter property="drId" jdbcType="INTEGER" mode="IN"/>
  4. <parameter property="partnerId" jdbcType="INTEGER" mode="IN"/>
  5. <parameter property="customerId" jdbcType="INTEGER" mode="IN"/>
  6. <parameter property="pcsCount" jdbcType="INTEGER" mode="OUT"/>
  7. <parameter property="drCount" jdbcType="INTEGER" mode="OUT"/>
  8. </parameterMap>

javaBean可以通过两种来进行映射

  1. <resultMap type="com.polysaas.mdm.device.entity.HomeVO" id="home">
  2. <result column="partnerId" property="partnerId" jdbcType="INTEGER"/>
  3. <result column="customerId" property="customerId" jdbcType="INTEGER" />
  4. <result column="pcsId" property="pcsId" jdbcType="INTEGER" />
  5. <result column="drId" property="drId" jdbcType="INTEGER" />
  6. <result column="pcsCount" property="pcsCount" jdbcType="INTEGER" />
  7. <result column="drCount" property="drCount" jdbcType="INTEGER" />
  8. </resultMap>
  9. <select id="selectForHome2" parameterType="com.polysaas.mdm.device.entity.HomeVO"
  10. statementType="CALLABLE">
  11. {call selectCount(
  12. #{pcsId,jdbcType=INTEGER, mode=IN},
  13. #{drId, jdbcType=INTEGER,mode=IN},
  14. #{partnerId, jdbcType=INTEGER,mode=IN},
  15. #{customerId, jdbcType=INTEGER,mode=IN},
  16. #{pcsCount, jdbcType=INTEGER,mode=OUT},
  17. #{drCount, jdbcType=INTEGER,mode=OUT}
  18. )}
  19. </select>

2.2 通过javabean传递参数  java调用写法

  1. @Override
  2. public HomeVO selectHomeCount(HomeVO home) throws Exception {
  3. HomeVO vo = new HomeVO();
  4. vo.setPcsId(0);
  5. vo.setDrId(0);
  6. vo.setPartnerId(25);
  7. vo.setCustomerId(50);
  8. vo.setPcsCount(0);
  9. vo.setDrCount(0);
  10. selectOne("com.polysaas.mdm.device.mapper.MdmDeviceMapper.selectForHome2", vo);
  11. return vo;
  12. }

遇到异常很多。。记得的写下

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存储过程 带输出输入参数的更多相关文章

  1. java, mybatis, 调用mysql存储过程

    Map<String, Object> bindinfo = new HashMap<String, Object>();            bindinfo.put(&q ...

  2. Mybatis调用Mysql存储过程

    在我的后台系统中,今天需要使用到存储过程.存储过程还真没写过,今天就写了个存储过程.使用在后台中. 其实这个接口功能  是涉及几张表的修改,删除,新增的.就写个一个存储过程. 存储过程: ), ),) ...

  3. mybatis调用mysql的存储过程(procedure),实现查询操作(student表中的某个年级中的总人数 select (1) 或者 select (*))

    step1:在mysql cmd中新建存储过程: drop procedure if exists queryCountByGrade ; delimiter // -- 定义存储过程结束符号为// ...

  4. spring mybatis 3.2调用mysql存储过程返回多结果集(完整、亲测、可用)

    最近,有个开发提了个需求,希望中间件支持调用mysql存储过程时支持多结果集返回,因为某些原因我们使用了不少的存储过程,很多复杂的逻辑目前来看交互非常的多,所以从当前的现状来说,这个需求还是蛮合理的. ...

  5. MySQL存储过程带in和out参数

    MySQL存储过程带in和out参数 最简单的例子: [html] mysql> DELIMITER $$ mysql> USE test $$ Database changed mysq ...

  6. MyBatis调用Oracle存储过程

    MyBatis调用Oracle存储过程 1.无输入和输出参数的存储过程 2.带有输入和输出参数的存储过程 3.返回游标的存储过程 mybatis中的配置文件代码 <resultMap type= ...

  7. Mybatis调用PostgreSQL存储过程实现数组入参传递

    注:本文来源于 < Mybatis调用PostgreSQL存储过程实现数组入参传递  > 前言 项目中用到了Mybatis调用PostgreSQL存储过程(自定义函数)相关操作,由于Pos ...

  8. PHP调用MYSQL存储过程实例

    PHP调用MYSQL存储过程实例 标签: mysql存储phpsqlquerycmd 2010-09-26 11:10 11552人阅读 评论(3) 收藏 举报 实例一:无参的存储过程$conn = ...

  9. 调用MYSQL存储过程实例

    PHP调用MYSQL存储过程实例 http://blog.csdn.net/ewing333/article/details/5906887 http://www.cnblogs.com/kkchen ...

随机推荐

  1. openwrt上网配置的一些理解(四)

    这次要解决的问题是3g上网和wan口上往可以随意切换,当然能够叠加也是好事,不过这不是我关心的.下面还是修改3个文件network,firewall,multiwan.首先在network中加入界面配 ...

  2. [开源夏令营][四] Docker remote API 之 镜像篇

    列出镜像 列出镜像,有两个可选參数,一个是all,一个是filter,all可选值有,0/False/false,1/True/true,默觉得0:filter是一个包括一个过滤对象的json,形式如 ...

  3. Python:常见错误集锦(持续更新ing)

    初学Python,很容易与各种错误不断的遭遇.通过集锦,可以快速的找到错误的原因和解决方法. 1.IndentationError:expected an indented block 说明此处需要缩 ...

  4. iOS分享 - 对象间的通信之delegate、notificationCenter与block

    在项目开发中,常常会涉及到对象之间的通信,而为了降低对象间的耦合,会采用delegate.notificationCenter.block三种方式来进行实现,对于他们的使用,也许大家都能熟练掌握,但是 ...

  5. Java语言实现简单FTP软件------>FTP软件效果图预览之下载功能(二)

    介绍完FTP协议后,来看看该软件完成后的效果图 客户端的主界面如上图所示,主要是分为以下几个界面: 数据输入界面:用来让用户输入服务器的地址,用户名,密码,端口号等. 站点菜单.本地菜单.远程菜单以及 ...

  6. JS/CSS/IMG加载顺序关系之DOMContentLoaded事件

    DOMContentLoaded介绍 DOMContentLoaded事件的触发条件是: 将会在“所有的DOM全部加载完毕并且JS加载执行后触发”. 但如果“js是通过动态加载进来的话,是不会影响到D ...

  7. 理解jquery的.on()方法

    jquery在的.on()方法用来给元素绑定事件处理函数的,我经常用在两个地方: 给未来的元素绑定事件:我总是这样用:$(document).on('click','#div1',function() ...

  8. 根据反射生成SQL语句

    /** * 基础查询语句 * 返回类型的属性字符串Sql * @author: InkYi * 修改时间:2016年5月11日 - 上午10:06:00<br/> * 功能说明:<b ...

  9. Hadoop学习历程(四、运行一个真正的MapReduce程序)

    上次的程序只是操作文件系统,本次运行一个真正的MapReduce程序. 运行的是官方提供的例子程序wordcount,这个例子类似其他程序的hello world. 1. 首先确认启动的正常:运行 s ...

  10. 本原串(HDU 2197 快速幂)

    本原串 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...