|
@@ -4,6 +4,7 @@ import com.google.common.base.CaseFormat;
|
|
|
import com.google.gson.Gson;
|
|
|
import com.zanxiang.game.data.serve.pojo.dto.*;
|
|
|
import com.zanxiang.game.data.serve.pojo.entity.AdsGamePitcherDay;
|
|
|
+import com.zanxiang.game.data.serve.pojo.entity.AdsPitcherDay;
|
|
|
import com.zanxiang.game.data.serve.pojo.entity.AdsPitcherGameDayn;
|
|
|
import com.zanxiang.game.data.serve.pojo.enums.OrderByEnum;
|
|
|
import com.zanxiang.game.data.serve.pojo.vo.*;
|
|
@@ -47,10 +48,15 @@ import java.util.stream.Collectors;
|
|
|
@Slf4j
|
|
|
public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
//存储PitcherGameDataDayVO的映射
|
|
|
- private static final List<Tuple2<Field, Field>> dayNFieldMapList;
|
|
|
+ private static final List<Tuple2<Field, Field>> pitcherGameDayNFieldMapList;
|
|
|
//存储PitcherGameDataDayTotalVO的映射
|
|
|
- private static final List<Tuple2<Field, Field>> dayNTotalFieldMapList;
|
|
|
-
|
|
|
+ private static final List<Tuple2<Field, Field>> pitcherGameDayNTotalFieldMapList;
|
|
|
+ //存储PitcherDataDayVO的映射
|
|
|
+ private static final List<Tuple2<Field, Field>> pitcherDayNFieldMapList;
|
|
|
+ //存储PitcherDataDayTotalVO的映射
|
|
|
+ private static final List<Tuple2<Field, Field>> pitcherDayNTotalFieldMapList;
|
|
|
+
|
|
|
+ //解析投手游戏每日数据及总计一栏相关的映射
|
|
|
static {
|
|
|
//解析PitcherGameDataDayVO的映射
|
|
|
Map<String, Field> fieldMap = new HashMap<>();
|
|
@@ -72,15 +78,15 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
tempClazz = tempClazz.getSuperclass();
|
|
|
}
|
|
|
if (dayNFieldList.isEmpty()) {
|
|
|
- dayNFieldMapList = Collections.emptyList();
|
|
|
+ pitcherGameDayNFieldMapList = Collections.emptyList();
|
|
|
} else {
|
|
|
- dayNFieldMapList = new ArrayList<>(dayNFieldList.size());
|
|
|
+ pitcherGameDayNFieldMapList = new ArrayList<>(dayNFieldList.size());
|
|
|
for (Field field : dayNFieldList) {
|
|
|
field.setAccessible(true);
|
|
|
Field sourceField = fieldMap.get(field.getName().replace("Trend", ""));
|
|
|
sourceField.setAccessible(true);
|
|
|
if (sourceField != null) {
|
|
|
- dayNFieldMapList.add(Tuples.of(sourceField, field));
|
|
|
+ pitcherGameDayNFieldMapList.add(Tuples.of(sourceField, field));
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -105,19 +111,79 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
tempTotalClazz = tempTotalClazz.getSuperclass();
|
|
|
}
|
|
|
if (dayNTotalFieldList.isEmpty()) {
|
|
|
- dayNTotalFieldMapList = Collections.emptyList();
|
|
|
+ pitcherGameDayNTotalFieldMapList = Collections.emptyList();
|
|
|
} else {
|
|
|
- dayNTotalFieldMapList = new ArrayList<>(dayNTotalFieldList.size());
|
|
|
+ pitcherGameDayNTotalFieldMapList = new ArrayList<>(dayNTotalFieldList.size());
|
|
|
for (Field field : dayNTotalFieldList) {
|
|
|
field.setAccessible(true);
|
|
|
Field sourceField = fieldTotalMap.get(field.getName().replace("Trend", ""));
|
|
|
sourceField.setAccessible(true);
|
|
|
if (sourceField != null) {
|
|
|
- dayNTotalFieldMapList.add(Tuples.of(sourceField, field));
|
|
|
+ pitcherGameDayNTotalFieldMapList.add(Tuples.of(sourceField, field));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ //解析投手每日数据及总计一栏相关的的映射
|
|
|
+ static {
|
|
|
+ //解析PitcherDataDayVO映射
|
|
|
+ Map<String, Field> pitcherDayFieldMap = new HashMap<>();
|
|
|
+ List<Field> pitcherDayDayNList = new ArrayList<>();
|
|
|
+ Class<?> pitcherDayClazz = PitcherDataDayVO.class;
|
|
|
+ while (pitcherDayClazz != null) {
|
|
|
+ Field[] fields = pitcherDayClazz.getDeclaredFields();
|
|
|
+ for (Field field : fields) {
|
|
|
+ if (Modifier.isFinal(field.getModifiers()) || Modifier.isStatic(field.getModifiers())) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ pitcherDayFieldMap.put(field.getName(), field);
|
|
|
+ if (field.getType() == RechargeTrendVO.class) {
|
|
|
+ pitcherDayDayNList.add(field);
|
|
|
}
|
|
|
}
|
|
|
+ pitcherDayClazz = pitcherDayClazz.getSuperclass();
|
|
|
+ }
|
|
|
+ if (pitcherDayDayNList.isEmpty()) {
|
|
|
+ pitcherDayNFieldMapList = Collections.emptyList();
|
|
|
+ } else {
|
|
|
+ pitcherDayNFieldMapList = new ArrayList<>(pitcherDayDayNList.size());
|
|
|
+ for (Field field : pitcherDayDayNList) {
|
|
|
+ field.setAccessible(true);
|
|
|
+ Field soureField = pitcherDayFieldMap.get(field.getName().replace("Trend", ""));
|
|
|
+ soureField.setAccessible(true);
|
|
|
+ pitcherDayNFieldMapList.add(Tuples.of(soureField, field));
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
+ //解析PitcherDataDayTotalVO映射
|
|
|
+ Map<String, Field> pitcherDayTotalMap = new HashMap<>();
|
|
|
+ List<Field> pitcherDayTotalList = new ArrayList<>();
|
|
|
+ Class<?> pitcherDayTotalClazz = PitcherDataDayTotalVO.class;
|
|
|
+ while (pitcherDayTotalClazz != null) {
|
|
|
+ Field[] fields = pitcherDayTotalClazz.getDeclaredFields();
|
|
|
+ for (Field field : fields) {
|
|
|
+ if (Modifier.isFinal(field.getModifiers()) || Modifier.isStatic(field.getModifiers())) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ pitcherDayTotalMap.put(field.getName(), field);
|
|
|
+ if (field.getType() == RechargeTrendVO.class) {
|
|
|
+ pitcherDayTotalList.add(field);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ pitcherDayTotalClazz = pitcherDayTotalClazz.getSuperclass();
|
|
|
+ }
|
|
|
+ if (pitcherDayTotalList.isEmpty()) {
|
|
|
+ pitcherDayNTotalFieldMapList = Collections.emptyList();
|
|
|
+ } else {
|
|
|
+ pitcherDayNTotalFieldMapList = new ArrayList<>(pitcherDayTotalList.size());
|
|
|
+ for (Field field : pitcherDayTotalList) {
|
|
|
+ field.setAccessible(true);
|
|
|
+ Field sourceField = pitcherDayTotalMap.get(field.getName().replace("Trend", ""));
|
|
|
+ sourceField.setAccessible(true);
|
|
|
+ pitcherDayNTotalFieldMapList.add(Tuples.of(sourceField, field));
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
@Autowired
|
|
@@ -130,7 +196,53 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
*/
|
|
|
@Override
|
|
|
public Page<PitcherDataDayVO> getPitcherDataDay(PitcherDataDayDTO dto) {
|
|
|
- return null;
|
|
|
+ //不传递时间,默认查询当天
|
|
|
+ if (dto.getBeginDate() == null || dto.getEndDate() == null ) {
|
|
|
+ dto.setBeginDate(LocalDate.now());
|
|
|
+ dto.setEndDate(LocalDate.now());
|
|
|
+ }
|
|
|
+ //创建查询条件
|
|
|
+ Criteria cri = Cnd.cri();
|
|
|
+ if (dto.getPitcherId() != null) {
|
|
|
+ cri.where().andEquals("pitcher_id", dto.getPitcherId());
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(dto.getSourceSystem())) {
|
|
|
+ cri.where().andEquals("source_system", dto.getSourceSystem());
|
|
|
+ }
|
|
|
+ if (dto.getBeginDate() != null && dto.getEndDate() != null) {
|
|
|
+ cri.where().andBetween("dt", dto.getBeginDate(), dto.getEndDate());
|
|
|
+ }
|
|
|
+ //拼接排序条件,如果没有排序条件给默认值
|
|
|
+ if (StringUtils.isBlank(dto.getSortType())) {
|
|
|
+ dto.setSortType(OrderByEnum.DESC.getOrderType());
|
|
|
+ }
|
|
|
+ if (StringUtils.isBlank(dto.getSortFiled())) {
|
|
|
+ cri.getOrderBy().orderBy("dt", dto.getSortType());
|
|
|
+ cri.getOrderBy().orderBy("cost", dto.getSortType());
|
|
|
+ } else {
|
|
|
+ cri.getOrderBy().orderBy(CaseFormat.LOWER_CAMEL.to(CaseFormat.LOWER_UNDERSCORE, dto.getSortFiled()), dto.getSortType());
|
|
|
+ }
|
|
|
+ //Pager对象
|
|
|
+ Pager pager = dao.createPager(dto.getPageNum(), dto.getPageSize());
|
|
|
+ //sql语句
|
|
|
+ Sql sql = Sqls.create(pitcherDataDaySql() + cri);
|
|
|
+ //设置回传对象
|
|
|
+ sql.setCallback(Sqls.callback.entities());
|
|
|
+ sql.setEntity(dao.getEntity(PitcherDataDayVO.class));
|
|
|
+ //设置pager
|
|
|
+ sql.setPager(pager);
|
|
|
+ //执行sql
|
|
|
+ dao.execute(sql);
|
|
|
+ //设置总记录数
|
|
|
+ pager.setRecordCount(dao.count(AdsPitcherDay.class, cri));
|
|
|
+ //处理dayN数据
|
|
|
+ List<PitcherDataDayVO> tempList = sql.getList(PitcherDataDayVO.class);
|
|
|
+ List<PitcherDataDayVO> list = tempList.stream().map(vo -> {
|
|
|
+ formatPitcherDataDayDayN(vo);
|
|
|
+ return vo;
|
|
|
+ }).collect(Collectors.toList());
|
|
|
+ //返回结果
|
|
|
+ return new Page<>(list, pager);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -140,7 +252,36 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
*/
|
|
|
@Override
|
|
|
public PitcherDataDayTotalVO getPitcherDataDayTotal(PitcherDataDayTotalDTO dto) {
|
|
|
- return null;
|
|
|
+ //不传递时间,默认查询当天
|
|
|
+ if (dto.getBeginDate() == null || dto.getEndDate() == null ) {
|
|
|
+ dto.setBeginDate(LocalDate.now());
|
|
|
+ dto.setEndDate(LocalDate.now());
|
|
|
+ }
|
|
|
+ //创建查询条件
|
|
|
+ Criteria cri = Cnd.cri();
|
|
|
+ if (dto.getPitcherId() != null) {
|
|
|
+ cri.where().andEquals("pitcher_id", dto.getPitcherId());
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(dto.getSourceSystem())) {
|
|
|
+ cri.where().andEquals("source_system", dto.getSourceSystem());
|
|
|
+ }
|
|
|
+ if (dto.getBeginDate() != null && dto.getEndDate() != null) {
|
|
|
+ cri.where().andBetween("dt", dto.getBeginDate(), dto.getEndDate());
|
|
|
+ }
|
|
|
+ //sql语句
|
|
|
+ Sql sql = Sqls.create(pitcherDataDayTotalSql() + cri);
|
|
|
+ //设置回传对象
|
|
|
+ sql.setCallback(Sqls.callback.entity());
|
|
|
+ sql.setEntity(dao.getEntity(PitcherDataDayTotalVO.class));
|
|
|
+ //执行sql
|
|
|
+ dao.execute(sql);
|
|
|
+ PitcherDataDayTotalVO vo = sql.getObject(PitcherDataDayTotalVO.class);
|
|
|
+ if (StringUtils.isNotBlank(vo.getAmountD1())) {
|
|
|
+ //处理dayN数据
|
|
|
+ formatPitcherDataDayTotalDayN(vo);
|
|
|
+ }
|
|
|
+
|
|
|
+ return vo;
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -175,13 +316,6 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
dto.setBeginDate(LocalDate.now());
|
|
|
dto.setEndDate(LocalDate.now());
|
|
|
}
|
|
|
- //默认排序字段
|
|
|
- if (StringUtils.isBlank(dto.getSortFiled())) {
|
|
|
- dto.setSortFiled("dt");
|
|
|
- }
|
|
|
- if (StringUtils.isBlank(dto.getSortType())) {
|
|
|
- dto.setSortType(OrderByEnum.DESC.getOrderType());
|
|
|
- }
|
|
|
//创建查询条件
|
|
|
Criteria cri = Cnd.cri();
|
|
|
if (dto.getPitcherId() != null) {
|
|
@@ -203,7 +337,16 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
cri.where().andEquals("game_type", dto.getGameType());
|
|
|
}
|
|
|
//排序条件
|
|
|
- cri.getOrderBy().orderBy(CaseFormat.LOWER_CAMEL.to(CaseFormat.LOWER_UNDERSCORE, dto.getSortFiled()), dto.getSortType());
|
|
|
+ //拼接排序条件,如果没有排序条件给默认值
|
|
|
+ if (StringUtils.isBlank(dto.getSortType())) {
|
|
|
+ dto.setSortType(OrderByEnum.DESC.getOrderType());
|
|
|
+ }
|
|
|
+ if (StringUtils.isBlank(dto.getSortFiled())) {
|
|
|
+ cri.getOrderBy().orderBy("dt", dto.getSortType());
|
|
|
+ cri.getOrderBy().orderBy("cost", dto.getSortType());
|
|
|
+ } else {
|
|
|
+ cri.getOrderBy().orderBy(CaseFormat.LOWER_CAMEL.to(CaseFormat.LOWER_UNDERSCORE, dto.getSortFiled()), dto.getSortType());
|
|
|
+ }
|
|
|
//Pager对象
|
|
|
Pager pager = dao.createPager(dto.getPageNum(), dto.getPageSize());
|
|
|
//sql语句
|
|
@@ -899,15 +1042,40 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * 处理DayN
|
|
|
+ * 处理投手游戏每日的DayN
|
|
|
+ *
|
|
|
+ * @param vo PitcherGameDataDayVO
|
|
|
+ */
|
|
|
+ private void formatPitcherDataDayDayN(PitcherDataDayVO vo) {
|
|
|
+ if (CollectionUtils.isEmpty(pitcherDayNFieldMapList)) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ pitcherDayNFieldMapList.forEach(dayNFieldMap -> {
|
|
|
+ try {
|
|
|
+ String[] temps = ((String) dayNFieldMap.getT1().get(vo)).split("/");
|
|
|
+ dayNFieldMap.getT2().set(vo, RechargeTrendVO.builder()
|
|
|
+ .rechargeMoney(new BigDecimal(temps[0]))
|
|
|
+ .rechargeUserCount(Long.valueOf(temps[1]))
|
|
|
+ .increase(new BigDecimal(temps[2]))
|
|
|
+ .back(new BigDecimal(temps[3]))
|
|
|
+ .multiples(new BigDecimal(temps[4]))
|
|
|
+ .build());
|
|
|
+ } catch (Exception e) {
|
|
|
+ throw new BaseException("映射出错");
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 处理投手游戏每日的DayN
|
|
|
*
|
|
|
* @param vo PitcherGameDataDayVO
|
|
|
*/
|
|
|
private void formatPitcherGameDataDayDayN(PitcherGameDataDayVO vo) {
|
|
|
- if (CollectionUtils.isEmpty(dayNFieldMapList)) {
|
|
|
+ if (CollectionUtils.isEmpty(pitcherGameDayNFieldMapList)) {
|
|
|
return;
|
|
|
}
|
|
|
- dayNFieldMapList.forEach(dayNFieldMap -> {
|
|
|
+ pitcherGameDayNFieldMapList.forEach(dayNFieldMap -> {
|
|
|
try {
|
|
|
String[] temps = ((String) dayNFieldMap.getT1().get(vo)).split("/");
|
|
|
dayNFieldMap.getT2().set(vo, RechargeTrendVO.builder()
|
|
@@ -924,15 +1092,53 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * 处理DayN
|
|
|
+ * 处理投手每日总计的DayN
|
|
|
+ *
|
|
|
+ * @param vo PitcherDataDayTotalVO
|
|
|
+ */
|
|
|
+ private void formatPitcherDataDayTotalDayN(PitcherDataDayTotalVO vo) {
|
|
|
+ if (CollectionUtils.isEmpty(pitcherDayNTotalFieldMapList)) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ pitcherDayNTotalFieldMapList.forEach(dayNTotalFieldMap -> {
|
|
|
+ try {
|
|
|
+ //得到需要计算的值
|
|
|
+ String[] temps = ((String) dayNTotalFieldMap.getT1().get(vo)).split("/");
|
|
|
+ //dn的金额总计
|
|
|
+ BigDecimal dNAmount = new BigDecimal(temps[0]);
|
|
|
+ //d1-dn的金额总计
|
|
|
+ BigDecimal d1ToDNTotalAmount = new BigDecimal(temps[1]);
|
|
|
+ //d1-dn的消耗总计(排除了未到时间的cost)
|
|
|
+ BigDecimal d1ToDNTotalCost = new BigDecimal(temps[3]);
|
|
|
+ //d1的金额总计(排除了未到时间的d1)
|
|
|
+ BigDecimal d1Amount = new BigDecimal(temps[4]);
|
|
|
+ //赋值
|
|
|
+ dayNTotalFieldMap.getT2().set(vo, RechargeTrendVO.builder()
|
|
|
+ .rechargeMoney(dNAmount)
|
|
|
+ .rechargeUserCount(Long.valueOf(temps[2]))
|
|
|
+ .increase(d1ToDNTotalCost.compareTo(BigDecimal.ZERO) == 0 ? BigDecimal.ZERO :
|
|
|
+ dNAmount.divide(d1ToDNTotalCost, 4, RoundingMode.HALF_UP))
|
|
|
+ .back(d1ToDNTotalCost.compareTo(BigDecimal.ZERO) == 0 ? BigDecimal.ZERO :
|
|
|
+ d1ToDNTotalAmount.divide(d1ToDNTotalCost, 4, RoundingMode.HALF_UP))
|
|
|
+ .multiples(d1Amount.compareTo(BigDecimal.ZERO) == 0 ? BigDecimal.ZERO :
|
|
|
+ d1ToDNTotalAmount.divide(d1Amount, 4, RoundingMode.HALF_UP))
|
|
|
+ .build());
|
|
|
+ } catch (Exception e) {
|
|
|
+ throw new BaseException("映射出错");
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 处理投手游戏每日总计的DayN
|
|
|
*
|
|
|
* @param vo PitcherGameDataDayTotalVO
|
|
|
*/
|
|
|
private void formatPitcherGameDataDayTotalDayN(PitcherGameDataDayTotalVO vo) {
|
|
|
- if (CollectionUtils.isEmpty(dayNTotalFieldMapList)) {
|
|
|
+ if (CollectionUtils.isEmpty(pitcherGameDayNTotalFieldMapList)) {
|
|
|
return;
|
|
|
}
|
|
|
- dayNTotalFieldMapList.forEach(dayNTotalFieldMap -> {
|
|
|
+ pitcherGameDayNTotalFieldMapList.forEach(dayNTotalFieldMap -> {
|
|
|
try {
|
|
|
//得到需要计算的值
|
|
|
String[] temps = ((String) dayNTotalFieldMap.getT1().get(vo)).split("/");
|
|
@@ -962,20 +1168,16 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * 查询投手游戏每日数据SQL
|
|
|
+ * 查询投手每日数据SQL
|
|
|
* @return String
|
|
|
*/
|
|
|
- private String pitcherGameDataDaySql() {
|
|
|
+ private String pitcherDataDaySql() {
|
|
|
return """
|
|
|
SELECT
|
|
|
dt,
|
|
|
source_system,
|
|
|
pitcher_id,
|
|
|
- game_id,
|
|
|
pitcher,
|
|
|
- game_name,
|
|
|
- game_cp,
|
|
|
- game_type,
|
|
|
cost,
|
|
|
plan_count,
|
|
|
account_count,
|
|
@@ -1170,7 +1372,392 @@ public class PitcherDataServiceImpl implements IPitcherDataService {
|
|
|
role_num_rate,
|
|
|
new_user_amount_ratio
|
|
|
FROM
|
|
|
- game_ads.ads_game_pitcher_day
|
|
|
+ game_ads.ads_pitcher_day
|
|
|
+ """;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 查询投手游戏每日数据SQL
|
|
|
+ * @return String
|
|
|
+ */
|
|
|
+ private String pitcherGameDataDaySql() {
|
|
|
+ return """
|
|
|
+ SELECT
|
|
|
+ dt,
|
|
|
+ source_system,
|
|
|
+ pitcher_id,
|
|
|
+ game_id,
|
|
|
+ pitcher,
|
|
|
+ game_name,
|
|
|
+ game_cp,
|
|
|
+ game_type,
|
|
|
+ cost,
|
|
|
+ plan_count,
|
|
|
+ account_count,
|
|
|
+ agent_count,
|
|
|
+ register_num,
|
|
|
+ first_new_user_amount_count,
|
|
|
+ first_new_user_amount_num,
|
|
|
+ first_new_user_amount,
|
|
|
+ amount_count,
|
|
|
+ amount_num,
|
|
|
+ amount,
|
|
|
+ old_amount_count,
|
|
|
+ old_amount_num,
|
|
|
+ old_amount,
|
|
|
+ new_user_total_amount_count,
|
|
|
+ new_user_total_amount_num,
|
|
|
+ new_user_total_amount,
|
|
|
+ hundred_user_num,
|
|
|
+ buy_new_user_total_amount,
|
|
|
+ buy_new_user_total_amount_num,
|
|
|
+ buy_new_user_total_amount_count,
|
|
|
+ reg_order_user_again,
|
|
|
+ first_role_num,
|
|
|
+ new_user_total_role_num,
|
|
|
+ role_num,
|
|
|
+ register_cost,
|
|
|
+ first_roi,
|
|
|
+ buy_roi,
|
|
|
+ today_roi,
|
|
|
+ gross_profit,
|
|
|
+ first_rate,
|
|
|
+ buy_user_rate,
|
|
|
+ today_rate,
|
|
|
+ first_avg,
|
|
|
+ buy_avg,
|
|
|
+ today_avg,
|
|
|
+ paper_avg,
|
|
|
+ first_amount_cost,
|
|
|
+ buy_amount_cost,
|
|
|
+ today_amount_cost,
|
|
|
+ today_again_rate,
|
|
|
+ new_reg_arpu,
|
|
|
+ first_arpu,
|
|
|
+ today_arpu,
|
|
|
+ paper_arpu,
|
|
|
+ hundred_user_num_cost,
|
|
|
+ roi1,
|
|
|
+ roi2,
|
|
|
+ roi3,
|
|
|
+ roi4,
|
|
|
+ roi5,
|
|
|
+ roi6,
|
|
|
+ roi7,
|
|
|
+ roi8,
|
|
|
+ roi9,
|
|
|
+ roi10,
|
|
|
+ roi11,
|
|
|
+ roi12,
|
|
|
+ roi13,
|
|
|
+ roi14,
|
|
|
+ roi15,
|
|
|
+ roi16,
|
|
|
+ roi17,
|
|
|
+ roi18,
|
|
|
+ roi19,
|
|
|
+ roi20,
|
|
|
+ roi21,
|
|
|
+ roi22,
|
|
|
+ roi23,
|
|
|
+ roi24,
|
|
|
+ roi25,
|
|
|
+ roi26,
|
|
|
+ roi27,
|
|
|
+ roi28,
|
|
|
+ roi29,
|
|
|
+ roi30,
|
|
|
+ roi60,
|
|
|
+ roi90,
|
|
|
+ roi180,
|
|
|
+ roi1yaer,
|
|
|
+ roi_total,
|
|
|
+ amount_d1,
|
|
|
+ amount_d2,
|
|
|
+ amount_d3,
|
|
|
+ amount_d4,
|
|
|
+ amount_d5,
|
|
|
+ amount_d6,
|
|
|
+ amount_d7,
|
|
|
+ amount_d8,
|
|
|
+ amount_d9,
|
|
|
+ amount_d10,
|
|
|
+ amount_d11,
|
|
|
+ amount_d12,
|
|
|
+ amount_d13,
|
|
|
+ amount_d14,
|
|
|
+ amount_d15,
|
|
|
+ amount_d16,
|
|
|
+ amount_d17,
|
|
|
+ amount_d18,
|
|
|
+ amount_d19,
|
|
|
+ amount_d20,
|
|
|
+ amount_d21,
|
|
|
+ amount_d22,
|
|
|
+ amount_d23,
|
|
|
+ amount_d24,
|
|
|
+ amount_d25,
|
|
|
+ amount_d26,
|
|
|
+ amount_d27,
|
|
|
+ amount_d28,
|
|
|
+ amount_d29,
|
|
|
+ amount_m1,
|
|
|
+ amount_m2,
|
|
|
+ amount_m3,
|
|
|
+ amount_m6,
|
|
|
+ amount_y1,
|
|
|
+ amount_sum,
|
|
|
+ da1,
|
|
|
+ da2,
|
|
|
+ da3,
|
|
|
+ da4,
|
|
|
+ da5,
|
|
|
+ da6,
|
|
|
+ da7,
|
|
|
+ da8,
|
|
|
+ da9,
|
|
|
+ da10,
|
|
|
+ da11,
|
|
|
+ da12,
|
|
|
+ da13,
|
|
|
+ da14,
|
|
|
+ da15,
|
|
|
+ da16,
|
|
|
+ da17,
|
|
|
+ da18,
|
|
|
+ da19,
|
|
|
+ da20,
|
|
|
+ da21,
|
|
|
+ da22,
|
|
|
+ da23,
|
|
|
+ da24,
|
|
|
+ da25,
|
|
|
+ da26,
|
|
|
+ da27,
|
|
|
+ da28,
|
|
|
+ da29,
|
|
|
+ da30,
|
|
|
+ m2,
|
|
|
+ m3,
|
|
|
+ m6,
|
|
|
+ y1,
|
|
|
+ total,
|
|
|
+ da1_num,
|
|
|
+ da2_num,
|
|
|
+ da3_num,
|
|
|
+ da4_num,
|
|
|
+ da5_num,
|
|
|
+ da6_num,
|
|
|
+ da7_num,
|
|
|
+ da8_num,
|
|
|
+ da9_num,
|
|
|
+ da10_num,
|
|
|
+ da11_num,
|
|
|
+ da12_num,
|
|
|
+ da13_num,
|
|
|
+ da14_num,
|
|
|
+ da15_num,
|
|
|
+ da16_num,
|
|
|
+ da17_num,
|
|
|
+ da18_num,
|
|
|
+ da19_num,
|
|
|
+ da20_num,
|
|
|
+ da21_num,
|
|
|
+ da22_num,
|
|
|
+ da23_num,
|
|
|
+ da24_num,
|
|
|
+ da25_num,
|
|
|
+ da26_num,
|
|
|
+ da27_num,
|
|
|
+ da28_num,
|
|
|
+ da29_num,
|
|
|
+ da30_num,
|
|
|
+ m2_num,
|
|
|
+ m3_num,
|
|
|
+ m6_num,
|
|
|
+ y1_num,
|
|
|
+ total_num,
|
|
|
+ first_role_cost,
|
|
|
+ new_user_total_role_cost,
|
|
|
+ role_num_cost,
|
|
|
+ first_role_rate,
|
|
|
+ new_user_total_role_rate,
|
|
|
+ role_num_rate,
|
|
|
+ new_user_amount_ratio
|
|
|
+ FROM
|
|
|
+ game_ads.ads_game_pitcher_day
|
|
|
+ """;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 查询投手每日数据总计SQL
|
|
|
+ * @return String
|
|
|
+ */
|
|
|
+ private String pitcherDataDayTotalSql() {
|
|
|
+ return """
|
|
|
+ SELECT
|
|
|
+ SUM(cost) as cost,
|
|
|
+ SUM(plan_count) as plan_count,
|
|
|
+ SUM(account_count) as account_count,
|
|
|
+ SUM(agent_count) as agent_count,
|
|
|
+ SUM(register_num) as register_num,
|
|
|
+ ROUND(IF(SUM(register_num) > 0, SUM(cost) / SUM(register_num), 0), 2) as register_cost,
|
|
|
+ SUM(first_role_num) as first_role_num,
|
|
|
+ SUM(new_user_total_role_num) as new_user_total_role_num,
|
|
|
+ SUM(role_num) as role_num,
|
|
|
+ ROUND(IF(SUM(role_num) > 0 , SUM(cost) / SUM(role_num), 0), 2) as role_num_cost,
|
|
|
+ ROUND(IF(SUM(first_role_num) > 0 , SUM(cost) / SUM(first_role_num), 0), 2) as first_role_cost,
|
|
|
+ ROUND(IF(SUM(new_user_total_role_num) > 0 , SUM(cost) / SUM(new_user_total_role_num), 0), 2) as new_user_total_role_cost,
|
|
|
+ ROUND(IF(SUM(register_num) > 0 , SUM(first_role_num) / SUM(register_num), 0), 4) as first_role_rate,
|
|
|
+ ROUND(IF(SUM(register_num) > 0 , SUM(new_user_total_role_num) / SUM(register_num), 0), 4) as new_user_total_role_rate,
|
|
|
+ ROUND(IF(SUM(register_num) > 0 , SUM(role_num) / SUM(register_num), 0), 4) as role_num_rate,
|
|
|
+ SUM(first_new_user_amount_count) as first_new_user_amount_count,
|
|
|
+ SUM(first_new_user_amount_num) as first_new_user_amount_num,
|
|
|
+ SUM(first_new_user_amount) as first_new_user_amount,
|
|
|
+ SUM(amount_count) as amount_count,
|
|
|
+ SUM(amount_num) as amount_num,
|
|
|
+ SUM(amount) as amount,
|
|
|
+ SUM(old_amount_count) as old_amount_count,
|
|
|
+ SUM(old_amount_num) as old_amount_num,
|
|
|
+ SUM(old_amount) as old_amount,
|
|
|
+ SUM(new_user_total_amount_count) as new_user_total_amount_count,
|
|
|
+ SUM(new_user_total_amount_num) as new_user_total_amount_num,
|
|
|
+ SUM(new_user_total_amount) as new_user_total_amount,
|
|
|
+ SUM(buy_new_user_total_amount) as buy_new_user_total_amount,
|
|
|
+ SUM(buy_new_user_total_amount_num) as buy_new_user_total_amount_num,
|
|
|
+ SUM(buy_new_user_total_amount_count) as buy_new_user_total_amount_count,
|
|
|
+ ROUND(IF(SUM(cost) > 0, SUM(first_new_user_amount) / SUM(cost), 0), 4) as first_roi,
|
|
|
+ ROUND(IF(SUM(cost) > 0, SUM(buy_new_user_total_amount) / SUM(cost), 0), 4) as buy_roi,
|
|
|
+ ROUND(IF(SUM(cost) > 0, SUM(new_user_total_amount) / SUM(cost), 0), 4) as today_roi,
|
|
|
+ (SUM(new_user_total_amount) - SUM(cost)) as gross_profit,
|
|
|
+ ROUND(IF(SUM(register_num) > 0, SUM(first_new_user_amount_num) / SUM(register_num), 0), 4) as first_rate,
|
|
|
+ ROUND(IF(SUM(register_num) > 0, SUM(buy_new_user_total_amount_num) / SUM(register_num), 0), 4) as buy_user_rate,
|
|
|
+ ROUND(IF(SUM(register_num) > 0, SUM(new_user_total_amount_num) / SUM(register_num), 0), 4) as today_rate,
|
|
|
+ ROUND(IF(SUM(amount_num) > 0, SUM(first_new_user_amount_num) / SUM(amount_num), 0), 4) as new_user_amount_ratio,
|
|
|
+ ROUND(IF(SUM(first_new_user_amount_count) > 0 , SUM(first_new_user_amount) / SUM(first_new_user_amount_count), 0), 2) as first_avg,
|
|
|
+ ROUND(IF(SUM(buy_new_user_total_amount_count) > 0 , SUM(buy_new_user_total_amount) / SUM(buy_new_user_total_amount_count), 0), 2) as buy_avg,
|
|
|
+ ROUND(IF(SUM(new_user_total_amount_count) > 0 , SUM(new_user_total_amount) / SUM(new_user_total_amount_count), 0), 2) as today_avg,
|
|
|
+ ROUND(IF(SUM(amount_count) > 0 , SUM(amount) / SUM(amount_count), 0), 2) as paper_avg,
|
|
|
+ ROUND(IF(SUM(first_new_user_amount_num) > 0 , SUM(cost) / SUM(first_new_user_amount_num), 0), 2) as first_amount_cost,
|
|
|
+ ROUND(IF(SUM(buy_new_user_total_amount_num) > 0 , SUM(cost) / SUM(buy_new_user_total_amount_num), 0), 2) as buy_amount_cost,
|
|
|
+ ROUND(IF(SUM(new_user_total_amount_num) > 0 , SUM(cost) / SUM(new_user_total_amount_num), 0), 2) as today_amount_cost,
|
|
|
+ SUM(reg_order_user_again) as reg_order_user_again,
|
|
|
+ ROUND(IF(SUM(new_user_total_amount_num) > 0 ,SUM(reg_order_user_again) / SUM(new_user_total_amount_num), 0), 4) as today_again_rate,
|
|
|
+ ROUND(IF(SUM(register_num) > 0 , SUM(new_user_total_amount) / SUM(register_num), 0), 2) as new_reg_arpu,
|
|
|
+ ROUND(IF(SUM(first_new_user_amount_num) > 0 , SUM(first_new_user_amount) / SUM(first_new_user_amount_num), 0), 2) as first_arpu,
|
|
|
+ ROUND(IF(SUM(new_user_total_amount_num) > 0 , SUM(new_user_total_amount) / SUM(new_user_total_amount_num), 0), 2) as today_arpu,
|
|
|
+ ROUND(IF(SUM(amount_num) > 0 , SUM(amount) / SUM(amount_num), 0), 2) as paper_arpu,
|
|
|
+ SUM(hundred_user_num) as hundred_user_num,
|
|
|
+ ROUND(IF(SUM(hundred_user_num) > 0 , SUM(cost) / SUM(hundred_user_num), 0), 2) as hundred_user_num_cost,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da1) / SUM(cost), 0), 4) as roi1,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da2) / SUM(cost), 0), 4) as roi2,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da3) / SUM(cost), 0), 4) as roi3,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da4) / SUM(cost), 0), 4) as roi4,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da5) / SUM(cost), 0), 4) as roi5,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da6) / SUM(cost), 0), 4) as roi6,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da7) / SUM(cost), 0), 4) as roi7,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da8) / SUM(cost), 0), 4) as roi8,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da9) / SUM(cost), 0), 4) as roi9,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da10) / SUM(cost), 0), 4) as roi10,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da11) / SUM(cost), 0), 4) as roi11,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da12) / SUM(cost), 0), 4) as roi12,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da13) / SUM(cost), 0), 4) as roi13,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da14) / SUM(cost), 0), 4) as roi14,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da15) / SUM(cost), 0), 4) as roi15,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da16) / SUM(cost), 0), 4) as roi16,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da17) / SUM(cost), 0), 4) as roi17,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da18) / SUM(cost), 0), 4) as roi18,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da19) / SUM(cost), 0), 4) as roi19,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da20) / SUM(cost), 0), 4) as roi20,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da21) / SUM(cost), 0), 4) as roi21,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da22) / SUM(cost), 0), 4) as roi22,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da23) / SUM(cost), 0), 4) as roi23,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da24) / SUM(cost), 0), 4) as roi24,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da25) / SUM(cost), 0), 4) as roi25,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da26) / SUM(cost), 0), 4) as roi26,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da27) / SUM(cost), 0), 4) as roi27,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da28) / SUM(cost), 0), 4) as roi28,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da29) / SUM(cost), 0), 4) as roi29,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(da30) / SUM(cost), 0), 4) as roi30,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(m2) / SUM(cost), 0), 4) as roi60,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(m3) / SUM(cost), 0), 4) as roi90,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(m6) / SUM(cost), 0), 4) as roi180,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(y1) / SUM(cost), 0), 4) as roi1yaer,
|
|
|
+ ROUND(IF(SUM(cost) > 0 , SUM(total) / SUM(cost), 0), 4) as roi_total,
|
|
|
+ SUM(da1) as da1,
|
|
|
+ SUM(da2) as da2,
|
|
|
+ SUM(da3) as da3,
|
|
|
+ SUM(da4) as da4,
|
|
|
+ SUM(da5) as da5,
|
|
|
+ SUM(da6) as da6,
|
|
|
+ SUM(da7) as da7,
|
|
|
+ SUM(da8) as da8,
|
|
|
+ SUM(da9) as da9,
|
|
|
+ SUM(da10) as da10,
|
|
|
+ SUM(da11) as da11,
|
|
|
+ SUM(da12) as da12,
|
|
|
+ SUM(da13) as da13,
|
|
|
+ SUM(da14) as da14,
|
|
|
+ SUM(da15) as da15,
|
|
|
+ SUM(da16) as da16,
|
|
|
+ SUM(da17) as da17,
|
|
|
+ SUM(da18) as da18,
|
|
|
+ SUM(da19) as da19,
|
|
|
+ SUM(da20) as da20,
|
|
|
+ SUM(da21) as da21,
|
|
|
+ SUM(da22) as da22,
|
|
|
+ SUM(da23) as da23,
|
|
|
+ SUM(da24) as da24,
|
|
|
+ SUM(da25) as da25,
|
|
|
+ SUM(da26) as da26,
|
|
|
+ SUM(da27) as da27,
|
|
|
+ SUM(da28) as da28,
|
|
|
+ SUM(da29) as da29,
|
|
|
+ SUM(da30) as da30,
|
|
|
+ SUM(m2) as m2,
|
|
|
+ SUM(m3) as m3,
|
|
|
+ SUM(m6) as m6,
|
|
|
+ SUM(y1) as y1,
|
|
|
+ SUM(total) as total,
|
|
|
+ SUM(da1_num) as da1_num,
|
|
|
+ SUM(da2_num) as da2_num,
|
|
|
+ SUM(da3_num) as da3_num,
|
|
|
+ SUM(da4_num) as da4_num,
|
|
|
+ SUM(da5_num) as da5_num,
|
|
|
+ SUM(da6_num) as da6_num,
|
|
|
+ SUM(da7_num) as da7_num,
|
|
|
+ SUM(da8_num) as da8_num,
|
|
|
+ SUM(da9_num) as da9_num,
|
|
|
+ SUM(da10_num) as da10_num,
|
|
|
+ SUM(da11_num) as da11_num,
|
|
|
+ SUM(da12_num) as da12_num,
|
|
|
+ SUM(da13_num) as da13_num,
|
|
|
+ SUM(da14_num) as da14_num,
|
|
|
+ SUM(da15_num) as da15_num,
|
|
|
+ SUM(da16_num) as da16_num,
|
|
|
+ SUM(da17_num) as da17_num,
|
|
|
+ SUM(da18_num) as da18_num,
|
|
|
+ SUM(da19_num) as da19_num,
|
|
|
+ SUM(da20_num) as da20_num,
|
|
|
+ SUM(da21_num) as da21_num,
|
|
|
+ SUM(da22_num) as da22_num,
|
|
|
+ SUM(da23_num) as da23_num,
|
|
|
+ SUM(da24_num) as da24_num,
|
|
|
+ SUM(da25_num) as da25_num,
|
|
|
+ SUM(da26_num) as da26_num,
|
|
|
+ SUM(da27_num) as da27_num,
|
|
|
+ SUM(da28_num) as da28_num,
|
|
|
+ SUM(da29_num) as da29_num,
|
|
|
+ SUM(da30_num) as da30_num,
|
|
|
+ SUM(m2_num) as m2_num,
|
|
|
+ SUM(m3_num) as m3_num,
|
|
|
+ SUM(m6_num) as m6_num,
|
|
|
+ SUM(y1_num) as y1_num,
|
|
|
+ SUM(total_num) as total_num,
|
|
|
+ """ + getPitcherGameDataDayTotalDayNsql() +
|
|
|
+ """
|
|
|
+ FROM
|
|
|
+ game_ads.ads_pitcher_day
|
|
|
""";
|
|
|
}
|
|
|
|