mybatis 调用存储过程包含输入输出参数多结果集

一、首先定义存储过程,数据库环境mysql

 

Sql代码 

 收藏代码

  1. CREATE  PROCEDURE queryTotalNum(OUT totalNum INT , IN tableName varchar(40), IN conditions varchar(300))    
  2.    
  3. begin        
  4.    
  5.     declare stmt varchar(2000);       
  6.    
  7.     declare num int;    
  8.    
  9.     if LENGTH(conditions)>1 then      
  10.    
  11.     begin    
  12.    
  13.         set @sqlstr=concat('SELECT COUNT(*) INTO @num from ',tableName,' where ',conditions);    
  14.    
  15.     end;    
  16.    
  17.     else    
  18.    
  19.     begin    
  20.    
  21.          set @sqlstr=concat('SELECT COUNT(*) INTO @num from ',tableName);    
  22.   
  23.    
  24.     end;    
  25.    
  26.     end if;      
  27.    
  28.     prepare stmt from @sqlstr;        
  29.    
  30.     execute stmt;      
  31.    
  32.     deallocate prepare stmt;    
  33.    
  34.     set totalNum = @num;    
  35.    
  36.     select * from hdx_order_info LIMIT 0, 10 ;  
  37.     select * from hdx_proxy_distributor LIMIT 0, 10 ;  
  38.   
  39.     end;   

 二、配置mybatis文件

 

 

Java代码 

 收藏代码

  1. <!--Map作为存储过程输入输出参数  -->  
  2.   <select id="getNamesAndItems" statementType="CALLABLE" parameterType="Map"  resultMap="HdxOrderInfoMap,TestMap">    
  3.     {call queryTotalNum(#{totalNum,jdbcType=INTEGER,mode=OUT},#{tableName,jdbcType=INTEGER,mode=IN},#{conditions,jdbcType=INTEGER,mode=IN})}    
  4.   </select>   

 三、DAO类

 

 

Java代码 

 收藏代码

  1. public interface IHdxOrderInfoDao {  
  2.       
  3.     public List<List<?>> getNamesAndItems(Map<String,Object> map);  
  4.       
  5.       
  6. }  

 

 

四、services接口

Java代码 

 收藏代码

  1. public interface IHdxOrderInfoService  {  
  2.    
  3.  public List<List<?>> getNamesAndItems(Map<String,Object> map);  
  4. }  

 

五、services实现

Java代码 

 收藏代码

  1. public class HdxOrderInfoServiceImpl implements IHdxOrderInfoService{  
  2.     private IHdxOrderInfoDao hdxOrderInfoDao = null;  
  3.   
  4.       
  5.     public IHdxOrderInfoDao getHdxOrderInfoDao() {  
  6.         return hdxOrderInfoDao;  
  7.     }  
  8.   
  9.   
  10.     public void setHdxOrderInfoDao(IHdxOrderInfoDao hdxOrderInfoDao) {  
  11.         this.hdxOrderInfoDao = hdxOrderInfoDao;  
  12.     }  
  13.   
  14.   
  15.     public List<List<?>> getNamesAndItems(Map<String, Object> map) {  
  16.           
  17.         List<List<?>> list = this.hdxOrderInfoDao.getNamesAndItems(map);  
  18.           
  19.                 //totalNum是存储过程中的输出参数  
  20.         System.out.println(map.get("totalNum"));  
  21.           
  22.         //List<HdxOrderInfo> list0 = (List<HdxOrderInfo>)list.get(0);  
  23.         //List<HdxProxyDistributor> list1 = (List<HdxProxyDistributor>)list.get(1);  
  24.           
  25.         return list   
  26.     }  
  27. }  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值