| | |
| | | import com.iailab.module.data.common.enums.IndStatFuncEnum; |
| | | import com.iailab.module.data.common.enums.IndTimeLimitEnum; |
| | | import com.iailab.module.data.ind.data.dto.IndDataSetDTO; |
| | | import com.iailab.module.data.ind.data.service.IndDataSetFieldService; |
| | | import com.iailab.module.data.ind.data.service.IndDataSetService; |
| | | import com.iailab.module.data.ind.item.service.IndItemAtomService; |
| | | import com.iailab.module.data.ind.item.service.IndItemDerService; |
| | | import com.iailab.module.data.ind.item.vo.IndItemAtomVO; |
| | | import com.iailab.module.data.ind.item.vo.IndItemDerVO; |
| | | import com.iailab.module.data.ind.value.dto.QuerySourceValueDTO; |
| | | import org.apache.commons.lang3.StringUtils; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Component; |
| | | |
| | |
| | | private IndDataSetService indDataSetService; |
| | | |
| | | @Autowired |
| | | private IndDataSetFieldService indDataSetFieldService; |
| | | |
| | | @Autowired |
| | | private IndItemDerService indItemDerService; |
| | | |
| | | public final static String PATTERN_YEAR = "yyyy"; |
| | |
| | | if (indItem == null) { |
| | | return result; |
| | | } |
| | | result.setIndItemAtom(indItem); |
| | | IndDataSetDTO dataSet = indDataSetService.getDet(indItem.getDataSet()); |
| | | if (dataSet == null) { |
| | | return result; |
| | | } |
| | | result.setDataSource(indItem.getDataSource()); |
| | | StringBuilder selectSql = new StringBuilder(); |
| | | IndStatFuncEnum statFun = IndStatFuncEnum.getEumByCode(indItem.getStatFunc()); |
| | | IndStatFuncEnum statFun = IndStatFuncEnum.getEumByCode(StringUtils.isBlank(indItem.getStatFunc())? IndStatFuncEnum.DEFAULT.getCode() : indItem.getStatFunc()); |
| | | switch (statFun) { |
| | | case AVG: |
| | | selectSql.append("AVG("); |
| | |
| | | case SUM: |
| | | selectSql.append("SUM("); |
| | | break; |
| | | default: |
| | | case DEFAULT: |
| | | selectSql.append("("); |
| | | break; |
| | | } |
| | |
| | | |
| | | // 拼接SELECT |
| | | StringBuilder selectSql = new StringBuilder(); |
| | | selectSql.append(indItem.getDimension()); |
| | | selectSql.append(", "); |
| | | selectSql.append(result.getSelectSql()); |
| | | selectSql.append(", "); |
| | | selectSql.append(indItem.getTimeLabel()); |
| | | selectSql.append(" data_time"); |
| | | if (StringUtils.isNotBlank(indItem.getDimension()) && StringUtils.isNotBlank(result.getIndItemAtom().getStatFunc())){ |
| | | selectSql.append(indItem.getDimension()); |
| | | selectSql.append(", "); |
| | | selectSql.append(result.getSelectSql()); |
| | | } |
| | | if(StringUtils.isBlank(indItem.getDimension()) && StringUtils.isNotBlank(result.getIndItemAtom().getStatFunc())){ |
| | | selectSql.append(result.getSelectSql()); |
| | | } |
| | | else{ |
| | | selectSql.append(result.getSelectSql()); |
| | | selectSql.append(", "); |
| | | selectSql.append(indItem.getTimeLabel()); |
| | | selectSql.append(" data_time"); |
| | | } |
| | | result.setSelectSql(selectSql.toString()); |
| | | |
| | | // 拼接WHERE |
| | |
| | | whereSql.append(indItem.getTimeLabel()); |
| | | whereSql.append(" <= '"); |
| | | whereSql.append(DateUtils.format(calendar.getTime(), PATTERN_MON)); |
| | | whereSql.append("' AND >= '"); |
| | | whereSql.append("' AND '"); |
| | | whereSql.append(indItem.getTimeLabel()); |
| | | whereSql.append("' >= '"); |
| | | calendar.add(Calendar.MONTH, -12); |
| | | whereSql.append(DateUtils.format(calendar.getTime(), PATTERN_MON)); |
| | | whereSql.append("'"); |
| | |
| | | whereSql.append("'"); |
| | | break; |
| | | case CUSTOM: |
| | | whereSql.append(indItem.getTimeLabel()); |
| | | whereSql.append(" <= '"); |
| | | whereSql.append(DateUtils.format(indItem.getTimeEnd(), PATTERN_MON)); |
| | | whereSql.append("' AND >= '"); |
| | | whereSql.append("' AND "); |
| | | whereSql.append(indItem.getTimeLabel()); |
| | | whereSql.append(" >= '"); |
| | | whereSql.append(DateUtils.format(indItem.getTimeStart(), PATTERN_MON)); |
| | | whereSql.append("'"); |
| | | break; |
| | |
| | | |
| | | // 拼接GROUP |
| | | StringBuilder groupSql = new StringBuilder(); |
| | | groupSql.append(" GROUP BY "); |
| | | groupSql.append(indItem.getDimension()); |
| | | if (StringUtils.isNotBlank(indItem.getDimension())){ |
| | | groupSql.append(indItem.getDimension()); |
| | | } |
| | | result.setGroupSql(groupSql.toString()); |
| | | |
| | | // 拼接ORDER |
| | | StringBuilder orderBySql = new StringBuilder(); |
| | | orderBySql.append(indItem.getTimeLabel()); |
| | | result.setOrderBySql(orderBySql.toString()); |
| | | if (StringUtils.isNotBlank(indItem.getDimension()) && indItem.getDimension().equals(indItem.getTimeLabel())){ |
| | | orderBySql.append(indItem.getTimeLabel()); |
| | | result.setOrderBySql(orderBySql.toString()); |
| | | } |
| | | return result; |
| | | } |
| | | |