Mybatis 返回map返回两列值 分别为key value

Mybatis 返回map返回两列值 分别为key value

一 先在Mapper.xml 添加key 和 value 的对应值


    
    
  


注:CONCAT(recordTime,’,’,device_code) mysql 字段拼接

二,实现ResultHandler的实现类(将map结果进行对应的封装)

public class MyResultHandler implements ResultHandler {
    @SuppressWarnings("rawtypes")
    private final HashMap mappedResults = new HashMap();

    @SuppressWarnings("unchecked")
    @Override
    public void handleResult(ResultContext context) {
        @SuppressWarnings("rawtypes")
        Map map = (Map) context.getResultObject();
        mappedResults.put(map.get("key"), map.get("value")); // xml配置里面的property的值,对应的列
    }

    @SuppressWarnings("rawtypes")
    public HashMap getMappedResults() {
        return mappedResults;
    }
}

三,一个实现SqlSessionDaoSupport 接口的实现类 (在其中调用重写了ResultHandler的实现类的方法)

@Repository
public class SessionMapper extends SqlSessionDaoSupport {

    @Override
    @Resource
    @Autowired
    public void setSqlSessionFactory(SqlSessionFactory sqlSessionFactory) {
        super.setSqlSessionFactory(sqlSessionFactory);
    }

    /**
     * @return
     */
    @SuppressWarnings("unchecked")
    public HashMap selectDeviceHost(Map paramMap){
        MyResultHandler handler = new MyResultHandler();
        SessionMapper sessionMapper=new SessionMapper();
        //namespace : XxxMapper.xml 中配置的地址(XxxMapper.xml的qualified name)
        //.selectXxxxNum : XxxMapper.xml 中配置的方法名称
        //this.getSqlSession().select(namespace+".selectXxxxNum", handler);
        this.getSqlSession().select(DataDeviceEnergyHistoryMapper.class.getName()+".selectDeviceHost",paramMap, handler);
        HashMap map = handler.getMappedResults();
        return map;
    }
}

四,相应的service 层进行调用 OK

     Map   mapEnd=sessionMapper.selectDeviceHost(maParam);

注·:其实就是重写了mybatis的一套调用流程 使用我们自己重写后的方法实现查询结果的封装.

你可能感兴趣的:(Mybatis)