zoukankan      html  css  js  c++  java
  • 自定义Mybatis返回类型及注意事项

    一、自定义返回拦截器
    package com.yaoex.crm.service.util;

    import org.apache.ibatis.session.ResultContext;
    import org.apache.ibatis.session.ResultHandler;
    import org.apache.ibatis.session.SqlSessionFactory;
    import org.mybatis.spring.SqlSessionTemplate;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Component;

    import java.util.HashMap;
    import java.util.Map;

    /**
    * @Title: MapResultHandler
    * @Package: com.yaoex.crm.service.util
    * @description:
    **/

    @Component
    public class MapResultHandler implements ResultHandler {
    private static final Logger log = LoggerFactory.getLogger(MapResultHandler.class);

    private static SqlSessionTemplate sqlSessionTemplate;

    @Autowired
    public void setSqlSessionTemplate(SqlSessionFactory sqlSessionFactory) {
    MapResultHandler.sqlSessionTemplate = new SqlSessionTemplate(sqlSessionFactory);
    }

    @SuppressWarnings("rawtypes")
    private final Map mappedResults = new HashMap();

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

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

    public static Map getMapResults(String statementId,Map<String,Object> param){
    MapResultHandler handler = new MapResultHandler();
    sqlSessionTemplate.select(statementId,param,handler);
    return handler.getMappedResults();
    }
    }

    二、mybatis配置
    <resultMap id="levelCountMap" type="java.util.Map" >
    <result column="cust_level" property="key" jdbcType="INTEGER" />
    <result column="count" property="value" jdbcType="INTEGER" />
    </resultMap>

    <select id="selectCountByLevel" resultMap="levelCountMap">
    SELECT l.cust_level,COUNT(l.cust_level) as count from t_crm_customer_level l
    GROUP BY l.cust_level
    </select>

    三、调用方式
    Map<Integer,Long> results = MapResultHandler.getMapResults("com.yaoex.crm.dao.customerdata.CrmCustomerLevelDao.selectCountByLevel", null);
  • 相关阅读:
    Write an algorithm such that if an element in an MxN matrix is 0, its entire row and column is set to 0.
    旋转二维数组
    replace empty char with new string,unsafe method和native implementation的性能比较
    判断一字符串是否可以另一字符串重新排列而成
    移除重复字符的几个算法简单比较
    也来纠结一下字符串翻转
    判断重复字符存在:更有意义一点
    程序员常去网站汇总
    sublime
    针对程序集 'SqlServerTime' 的 ALTER ASSEMBLY 失败,因为程序集 'SqlServerTime' 未获授权(PERMISSION_SET = EXTERNAL_ACCESS)
  • 原文地址:https://www.cnblogs.com/xiaoxiaoccaiya/p/11082964.html
Copyright © 2011-2022 走看看