zoukankan      html  css  js  c++  java
  • 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()。

  • 相关阅读:
    读取exec返回值
    List
    面向对象设计原则
    CascadingDropDown省市县无刷新联动
    读写配置文件app.config
    变向实现动态水晶报表
    JS验证是否日期格式
    C#中调用API(转)
    (转自老赵Jeffrey Zhao)The status code returned from the server was: 12031”。(转)
    利用Javascript的“函数重载”实现自定义Alert样式
  • 原文地址:https://www.cnblogs.com/zhangtan/p/5828981.html
Copyright © 2011-2022 走看看