From 13ec337a0d24485d9f006cfd44ea5d69c00540f3 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期五, 11 一月 2019 16:21:22 +0800 Subject: [PATCH] 资金统计修改 --- fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java | 192 ++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 177 insertions(+), 15 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java index 3837520..dad8a40 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java @@ -1,5 +1,7 @@ package com.yeshi.fanli.service.impl.user; +import java.math.BigDecimal; +import java.text.DecimalFormat; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; @@ -15,6 +17,7 @@ import com.yeshi.fanli.dao.mybatis.user.UserActiveLogMapper; import com.yeshi.fanli.entity.bus.user.UserActiveLog; import com.yeshi.fanli.service.inter.user.UserActiveLogService; +import com.yeshi.fanli.util.MoneyBigDecimalUtil; @Service public class UserActiveLogServiceImpl implements UserActiveLogService { @@ -66,7 +69,156 @@ } } + @Override + public List<Object> countSameDayAndBuyGoodsByChannel(String channel, Integer type, String years, + String startTime, String endTime) throws Exception { + List<Map<String, Object>> list = userActiveLogMapper.countSameDayAndBuyGoodsByChannel(channel, type, years, + startTime, endTime); + + if (list == null || list.size() == 0) { + return null; + } + + switch (type){ + case 1: // 鎸夊ぉ澶勭悊 + return dayFactory(startTime, endTime, list); + case 2: // 鎸夋湀澶勭悊 + return monthFactory(list); + case 3: + return yearFactory(list); + default: + return null; + } + } + + @Override + public List<Map<String, Object>> countOneWeekUserInfo(String channel, String startTime, String endTime, + Integer orderNumber) throws Exception { + + // 鏃堕棿鍒楄〃 + List<String> dateList = new ArrayList<String>(); + // 缁撴灉鍒楄〃 + List<Map<String, Object>> resultList = new ArrayList<Map<String,Object>>(); + + String middleDay = ""; + for (int i = 0; i < 100 ; i++) { + if (i == 0) { + middleDay = startTime; + } else { + middleDay = DateUtil.plusDay(i, startTime); + } + + dateList.add(middleDay); + + if (middleDay.equals(endTime)) { + break; // 鏃堕棿缁撴潫 + } + } + + for (String nowDate: dateList) { + // 鍔犲叆7澶� + String plusDay = DateUtil.plusDay(7, nowDate); + + // 鎵ц鏌ヨ 骞惰繑鍥炵粨鏋� + Map<String, BigDecimal> map= userActiveLogMapper.countOneWeekUserInfo(channel, nowDate, plusDay, orderNumber); + + // 姣斾緥 + BigDecimal proportion = null; + + if (map != null) { + // 鏂板鐢ㄦ埛 + BigDecimal totalUser = map.get("totalUser"); + // 瀛樺湪璁㈠崟鐨勬柊澧炵敤鎴� + BigDecimal orderUser = map.get("orderUser"); + + try { + proportion = MoneyBigDecimalUtil.sub(orderUser, totalUser); + } catch (Exception e) { + e.printStackTrace(); + } + } + + if (proportion == null) { + proportion = new BigDecimal(0); + } + + Map<String, Object> result = new HashMap<String, Object>(); + result.put("showValue", MoneyBigDecimalUtil.mul(proportion, new BigDecimal(100))); + result.put("showDate", nowDate); + + resultList.add(result); + } + + return resultList; + + } + + + @Override + public List<Object> getBuyProportion(String channel, Integer type, String years, + String startTime, String endTime, Integer orderNum) throws Exception{ + + // 缁熻娓犻亾褰撴棩鏂板鐢ㄦ埛 + List<Object> countList = countSameDayByChannel(channel, type, years, startTime, endTime); + + if (countList == null || countList.size() == 0) { + return null; + } + + // 缁熻娓犻亾褰撴棩鏂板鐢ㄦ埛瀛樺湪涓嬪崟鐨勭敤鎴锋暟閲� + List<Object> countListBuy= null; + if (orderNum <= 1){ + countListBuy = countSameDayAndBuyGoodsByChannel(channel, type, years, startTime, endTime); + } + + if (countListBuy == null){ + new ArrayList<Object>(); + } + + List<Object> listObject = new ArrayList<Object>(); + + for (Object object: countList) { + + float rate = 0; + + Map<String, Object> mapObject = new HashMap<String, Object>(); + + Map<String, Object> map = (Map<String, Object>) object; + Object createDate = map.get("showDate"); + Object sameDayNum = map.get("showValue"); + + long totle = Long.parseLong(sameDayNum.toString()); + if (totle > 0 && countListBuy != null && countListBuy.size() > 0) { + for (int j = 0; j < countListBuy.size(); j++) { + Map<String, Object> mapBuy = (Map<String, Object>) countListBuy.get(j); + Object createDate2 = mapBuy.get("showDate"); + if (createDate.toString().equals(createDate2.toString())) { + Object buyNum = mapBuy.get("showValue"); + long totleBuy = Long.parseLong(buyNum.toString()); + rate = (float)totleBuy/totle; + break; + } + } + } + + DecimalFormat df = new DecimalFormat("0.00");//鏍煎紡鍖栧皬鏁� + mapObject.put("showValue", df.format(rate*100)); + mapObject.put("showDate", createDate); + listObject.add(mapObject); + } + + return listObject; + } + + /** + * 澶╂暟鏍煎紡 + * @param startTime + * @param endTime + * @param list + * @return + * @throws Exception + */ public List<Object> dayFactory(String startTime, String endTime, List<Map<String, Object>> list) throws Exception { List<Object> listObject = new ArrayList<Object>(); @@ -74,10 +226,10 @@ if (startTime.equals(endTime)) { Map<String, Object> map = list.get(0); - Object sameDayNum = map.get("sameDayNum"); + Object sameDayNum = map.get("showValue"); if (sameDayNum == null) { - map.put("sameDayNum", 0); + map.put("showValue", 0); } listObject.add(map); @@ -98,10 +250,10 @@ for (int j = 0; j < list.size(); j++) { Map<String, Object> map = list.get(j); - Object createDate = map.get("createDate"); + Object createDate = map.get("showDate"); String month = createDate.toString(); if (plusDay.equalsIgnoreCase(month)) { - sameDayNum = map.get("sameDayNum"); + sameDayNum = map.get("showValue"); break; } } @@ -109,13 +261,13 @@ if (sameDayNum == null) { sameDayNum = 0; } - mapObject.put("sameDayNum", sameDayNum); + mapObject.put("showValue", sameDayNum); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy/MM/dd"); Date parseDate = sdf.parse(plusDay.toString()); - mapObject.put("createDate", sdf2.format(parseDate)); + mapObject.put("showDate", sdf2.format(parseDate)); listObject.add(mapObject); @@ -127,7 +279,11 @@ return listObject; } - + /** + * 鏈堜唤鏍煎紡 + * @param list + * @return + */ public List<Object> monthFactory(List<Map<String, Object>> list) { List<Object> listObject = new ArrayList<Object>(); @@ -137,10 +293,10 @@ Object sameDayNum = null; for (int j = 0; j < list.size(); j++) { Map<String, Object> map = list.get(j); - Object createDate = map.get("createDate"); + Object createDate = map.get("showDate"); String month = createDate.toString(); if ((i+"").equalsIgnoreCase(month) || i == Integer.parseInt(month)) { - sameDayNum = map.get("sameDayNum"); + sameDayNum = map.get("showValue"); break; } } @@ -148,33 +304,39 @@ if (sameDayNum == null) { sameDayNum = 0; } - mapObject.put("sameDayNum", sameDayNum); + mapObject.put("showValue", sameDayNum); - mapObject.put("createDate", i + "鏈�"); + mapObject.put("showDate", i + "鏈�"); listObject.add(mapObject); } return listObject; } + /** + * 骞翠唤鏍煎紡 + * @param list + * @return + */ public List<Object> yearFactory(List<Map<String, Object>> list) { List<Object> listObject = new ArrayList<Object>(); for (int i = 0; i < list.size(); i++) { Map<String, Object> map = list.get(i); - Object sameDayNum = map.get("sameDayNum"); - Object createDate = map.get("createDate"); + Object sameDayNum = map.get("showValue"); + Object createDate = map.get("showDate"); if (sameDayNum == null) { sameDayNum = 0; } - map.put("sameDayNum", sameDayNum); - map.put("createDate", createDate + "骞�"); + map.put("showValue", sameDayNum); + map.put("showDate", createDate + "骞�"); listObject.add(map); } return listObject; } + } -- Gitblit v1.8.0