mybatis 调用mysql存储过程 带输出输入参数

首先感谢网络上以为朋友。其实我不认识。看到他的博客才做出来。

http://lohasle.iteye.com/blog/1669879 他的地址。下面的是我一些简单拓展的

 

 

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

Sql代码  收藏代码

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

 

 

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

1.1 mapper文件写法

Xml代码  收藏代码

  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调用写法

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.           
  12.             return map.get("drCount");  
  13.     }  

 

 

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

2.1 通过javabean传递参数  mapper写法

Xml代码  收藏代码

  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可以通过两种来进行映射

Xml代码  收藏代码

  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调用写法

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()。

 

转自:http://kesun-shy.iteye.com/blog/1959796

 

注:要获取存储过程的返回值,需要将输入参数放到map中传入,然后使用map.get("outoutparamname")获取

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值