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

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

CREATE  PROCEDURE queryTotalNum(OUT totalNum INT , IN tableName varchar(40), IN conditions varchar(300))  
 
begin      
 
    declare stmt varchar(2000);     
 
    declare num int;  
 
    if LENGTH(conditions)>1 then    
 
    begin  
 
        set @sqlstr=concat('SELECT COUNT(*) INTO @num from ',tableName,' where ',conditions);  
 
    end;  
 
    else  
 
    begin  
 
         set @sqlstr=concat('SELECT COUNT(*) INTO @num from ',tableName);  

 
    end;  
 
    end if;    
 
    prepare stmt from @sqlstr;      
 
    execute stmt;    
 
    deallocate prepare stmt;  
 
    set totalNum = @num;  
 
	select * from hdx_order_info LIMIT 0, 10 ;
  	select * from hdx_proxy_distributor LIMIT 0, 10 ;

    end; 


二、配置mybatis文件


   

 

三、DAO类

public interface IHdxOrderInfoDao {
	
	public List> getNamesAndItems(Map map);
	
	
}


四、services接口

public interface IHdxOrderInfoService  {
 
 public List> getNamesAndItems(Map map);
}

 

五、services实现

public class HdxOrderInfoServiceImpl implements IHdxOrderInfoService{
	private IHdxOrderInfoDao hdxOrderInfoDao = null;

	
	public IHdxOrderInfoDao getHdxOrderInfoDao() {
		return hdxOrderInfoDao;
	}


	public void setHdxOrderInfoDao(IHdxOrderInfoDao hdxOrderInfoDao) {
		this.hdxOrderInfoDao = hdxOrderInfoDao;
	}


	public List> getNamesAndItems(Map map) {
		
		List> list = this.hdxOrderInfoDao.getNamesAndItems(map);
		
                //totalNum是存储过程中的输出参数
		System.out.println(map.get("totalNum"));
		
		//List list0 = (List)list.get(0);
		//List list1 = (List)list.get(1);
		
		return list 
	}
}

 

你可能感兴趣的:(数据库,Java)