这个问题昨天困扰了我2个小时,终于在同事的开导下,这么写出来了,其实这种方法以前也写过,但是忘记了,现在发表到博客上面备忘。
/**
* 获取性别分析指标
*
* @author shangql
* @date 2013-1-17
* @param date
* @return
* @return List<Map<String,Object>>
*/
@Override
public List<Map<String, Object>> getGender(String countValue, String date, Integer[] brandIds) throws Exception {
Map<String, Object> inParamMap = new HashMap<String, Object>();
inParamMap.put("countValue", countValue);
inParamMap.put("date", date);
inParamMap.put("brandIdsList", parseToParam(brandIds));
inParamMap.put("size", EmptyUtil.isEmpty(brandIds)?0:brandIds.length);
List<Map<String, Object>> resultList = dao.queryForList("ConsumerInfoServiceImpl/getGender", inParamMap);
return nonEmpty(resultList);
}
/**
* 判断非空数据
*
* @author shangql
* @date 2013-1-23
* @param srcList
* @return
* @return List<Map<String,Object>>
*/
private List<Map<String, Object>> nonEmpty(List<Map<String, Object>> srcList) {
List<Map<String, Object>> resultList = new ArrayList<Map<String, Object>>();
Map<String, Object> itemMap = null;
if (EmptyUtil.isEmpty(srcList)) {
itemMap = new HashMap<String, Object>();
itemMap.put("name", "暂无数据");
itemMap.put("data1", 0);
resultList.add(itemMap);
return resultList;
} else {
return srcList;
}
}
/**
* 装配条件参数
*
* @author shangql
* @date 2013-1-24
* @param brandNames
* @return
* @return String
*/
private List<Map<String, Object>> parseToParam(Integer[] brandIds) throws Exception{
List<Map<String, Object>> resultList = new ArrayList<Map<String,Object>>();
Map<String, Object> itemMap = null;
if(!EmptyUtil.isEmpty(brandIds)){
for (Integer i : brandIds) {
itemMap = new HashMap<String, Object>();
itemMap.put("brandId", i);
resultList.add(itemMap);
}
}
return resultList;
}
mybaits SQl xml:
<!-- author: shangql date: 2013.01.17 desc:获取性别分析指标 -->
<select id="ConsumerInfoServiceImpl/getGender" parameterType="java.util.HashMap" resultType="java.util.HashMap">
SELECT dimension_brand.dimbrandid AS brandid,
dimension_brand.brandname AS name,
COALESCE(
(SELECT
COUNT(membersex) AS sexcount
FROM member_info
INNER JOIN sale_info
ON member_info.membercode = sale_info.membercode
AND member_info.licensecode = sale_info.licensecode
INNER JOIN dimension_goods
ON sale_info.goodsbarcode = dimension_goods.goodsbarcode
WHERE membersex = #{countValue}
AND dimension_brand.dimbrandid = brandId
GROUP BY dimension_goods.brandid
ORDER BY dimension_goods.brandid ASC)
,0) AS data1
FROM sale_info
INNER JOIN dimension_goods
ON sale_info.goodsbarcode = dimension_goods.goodsbarcode
INNER JOIN dimension_brand
ON dimension_goods.brandid = dimension_brand.dimbrandid
WHERE checkflag = '0'
AND membercode != '-1'
AND to_char(saletime,'yyyyMM') = #{date}
AND sale_info.goodsbarcode IN(SELECT goodsbarcode FROM goods_info)
<if test="size != 0">
AND dimension_brand.dimbrandid IN
<foreach item="item" collection="brandIdsList" open="(" separator="," close=")">
#{item.brandId}
</foreach>
</if>
GROUP BY dimension_brand.dimbrandid,dimension_brand.brandname
ORDER BY dimension_brand.dimbrandid ASC;
</select>
分享到:
相关推荐
Mybatis框架(子查询)
主要介绍了Mybatis plus中使用in查询出错的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
主要介绍了MyBatis之自查询使用递归实现 N级联动效果,本文给大家分享两种实现方式,需要的的朋友参考下吧
mybatis中文离线文档
mybatis多条件查询处理方案(查询条件为数据库字段非传递参数)
mybatis多表查询.zip
这是一个springboot架构搭建的一个整合mybatis递归查询的demo,其中整合了分布式事物jta,mybatis的分页插件等
主要介绍了mybatis分页绝对路径写法过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
这是一个非常基础你的mybatis实例,清晰易懂,非常适合初学者
本人博客中的代码Jsp+Servlet+MyBatis完成分页查询 http://blog.csdn.net/japanstudylang/article/details/51700874
Mybatis高级映射查询
spring多数据源的处理_mybatis实现跨库查询
MyBatis in Practice: A Step by Step Approach for Learning MyBatis Framework一书的源代码
mybatis实战教程mybatis in action之四实现关联数据的查询 mybatis实战教程mybatis in action之五与spring3集成附源码 mybatis实战教程mybatis in action之六与Spring MVC 的集成 mybatis实战教程mybatis in action...
Mybatis多参数查询与列表查询不同方式实现,效果看博文 http://blog.csdn.net/evankaka/article/details/45671473
mybatis一对多的查询方法详解! mybatis一对多的查询方法详解! mybatis一对多的查询方法详解! mybatis一对多的查询方法详解!
MyBatis 中文注释源码,直接导入eclipse工程即可,源码中加了中文注释,可以学习研究底层,成就自我成长!
mybatis定时任务列表查询分页切割,列表查询存在风险,在框架的层面使用拦截器完成列表的分页切割
MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。这篇文章主要介绍了MyBatis配置文件的写法和简单使用,需要的朋友参考下
主要介绍了MyBatis中的模糊查询语句的相关资料,需要的朋友可以参考下