Browse Source

网格员事件总数上报接口调整

dev
sunyuchao 4 years ago
parent
commit
a0a783cec7
  1. 116
      epmet-module/data-statistical/data-statistical-client/src/main/java/com/epmet/dto/crm/CustomerRelationDTO.java
  2. 12
      epmet-module/data-statistical/data-statistical-client/src/main/java/com/epmet/dto/stats/form/GmUploadEventFormDTO.java
  3. 8
      epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/dao/crm/CustomerRelationDao.java
  4. 7
      epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/service/crm/CustomerService.java
  5. 13
      epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/service/crm/impl/CustomerServiceImpl.java
  6. 29
      epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/service/impl/StatsUserServiceImpl.java
  7. 11
      epmet-module/data-statistical/data-statistical-server/src/main/resources/mapper/crm/CustomerRelationDao.xml
  8. 7
      epmet-module/data-statistical/data-statistical-server/src/main/resources/mapper/user/UserDao.xml

116
epmet-module/data-statistical/data-statistical-client/src/main/java/com/epmet/dto/crm/CustomerRelationDTO.java

@ -0,0 +1,116 @@
/**
* Copyright 2018 人人开源 https://www.renren.io
* <p>
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
* <p>
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* <p>
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.epmet.dto.crm;
import lombok.Data;
import java.io.Serializable;
import java.util.Date;
/**
* 客户关系表(01.14 add)
*
* @author generator generator@elink-cn.com
* @since v1.0.0 2021-02-03
*/
@Data
public class CustomerRelationDTO implements Serializable {
private static final long serialVersionUID = 1L;
/**
* 主键
*/
private String id;
/**
* 客户id
*/
private String customerId;
/**
* 父级客户id;如果是顶级客户此列=0
*/
private String parentCustomerId;
/**
* 当前客户的所有父级客户id,以英文冒号隔开如果是顶级客户此列=0
*/
private String pids;
/**
* 当前客户类型取值 external:外部客户internal:内部客户
*/
private String customerType;
/**
* 父级客户类型取值 external:外部客户internal:内部客户;如果是顶级客户此列=0
*/
private String parentCustomerType;
/**
* open,closed是否启用
*/
private String status;
/**
* 当前客户级别社区级community
街道:street,
区县级: district,
市级: city
省级:province
*/
private String level;
/**
* 当前客户的地区编码实际就是根组织的area_code
*/
private String areaCode;
/**
* 删除标识0未删除1已删除
*/
private String delFlag;
/**
* 乐观锁
*/
private Integer revision;
/**
* 创建人
*/
private String createdBy;
/**
* 创建时间
*/
private Date createdTime;
/**
* 更新人
*/
private String updatedBy;
/**
* 更新时间
*/
private Date updatedTime;
}

12
epmet-module/data-statistical/data-statistical-client/src/main/java/com/epmet/dto/stats/form/GmUploadEventFormDTO.java

@ -18,12 +18,6 @@ public class GmUploadEventFormDTO implements Serializable {
private static final long serialVersionUID = -9178779369245037701L; private static final long serialVersionUID = -9178779369245037701L;
//为true时需要删除历史数据 //为true时需要删除历史数据
private Boolean isFirst; private Boolean isFirst;
//客户Id
@NotBlank(message = "客户Id不能为空", groups = {UploadEvent.class})
private String customerId;
//日维度Id
@NotBlank(message = "dateId不能为空", groups = {UploadEvent.class})
private String dateId;
//数据集合对象 //数据集合对象
@NotEmpty(message = "数据集合对象不能为空",groups = UploadEvent.class) @NotEmpty(message = "数据集合对象不能为空",groups = UploadEvent.class)
private List<DataList> dataList; private List<DataList> dataList;
@ -31,8 +25,12 @@ public class GmUploadEventFormDTO implements Serializable {
@Data @Data
public static class DataList{ public static class DataList{
//客户Id 【dim_customer.id】 //来源类型 external:外部,internal:内部
private String sourceType;
//客户Id 【dim_customer.id】[接口传入的是来源数据的客户Id]
private String customerId; private String customerId;
//数据来源客户Id
private String parentCustomerId;
//机关Id 【dim_agency.id】 //机关Id 【dim_agency.id】
private String agencyId; private String agencyId;
//日维度Id 【dim_date.id】 //日维度Id 【dim_date.id】

8
epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/dao/crm/CustomerRelationDao.java

@ -18,6 +18,7 @@
package com.epmet.dao.crm; package com.epmet.dao.crm;
import com.epmet.commons.mybatis.dao.BaseDao; import com.epmet.commons.mybatis.dao.BaseDao;
import com.epmet.dto.crm.CustomerRelationDTO;
import com.epmet.dto.indexcal.CustomerSubInfoDTO; import com.epmet.dto.indexcal.CustomerSubInfoDTO;
import com.epmet.entity.crm.CustomerRelationEntity; import com.epmet.entity.crm.CustomerRelationEntity;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
@ -51,4 +52,11 @@ public interface CustomerRelationDao extends BaseDao<CustomerRelationEntity> {
* @date 2021/3/23 上午10:21 * @date 2021/3/23 上午10:21
*/ */
List<CustomerRelationEntity> selectSubCustomer(@Param("customerId") String customerId); List<CustomerRelationEntity> selectSubCustomer(@Param("customerId") String customerId);
/**
* @Description 查询客户所属父客户信息
* @author sun
*/
CustomerRelationDTO selectByCustomerId(@Param("customerId") String customerId);
} }

7
epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/service/crm/CustomerService.java

@ -1,5 +1,6 @@
package com.epmet.service.crm; package com.epmet.service.crm;
import com.epmet.dto.crm.CustomerRelationDTO;
import com.epmet.entity.crm.CustomerEntity; import com.epmet.entity.crm.CustomerEntity;
import java.util.Date; import java.util.Date;
@ -10,4 +11,10 @@ public interface CustomerService {
List<CustomerEntity> listValidCustomersByCreateTime(Date createTimeFrom, Date createTimeTo); List<CustomerEntity> listValidCustomersByCreateTime(Date createTimeFrom, Date createTimeTo);
List<CustomerEntity> listValidCustomersByUpdatedTime(Date updatedTime, Date initTime); List<CustomerEntity> listValidCustomersByUpdatedTime(Date updatedTime, Date initTime);
/**
* @Description 查询客户所属父客户信息
* @author sun
*/
CustomerRelationDTO getByCustomerId(String customerId);
} }

13
epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/service/crm/impl/CustomerServiceImpl.java

@ -3,6 +3,8 @@ package com.epmet.service.crm.impl;
import com.epmet.commons.dynamic.datasource.annotation.DataSource; import com.epmet.commons.dynamic.datasource.annotation.DataSource;
import com.epmet.constant.DataSourceConstant; import com.epmet.constant.DataSourceConstant;
import com.epmet.dao.crm.CustomerDao; import com.epmet.dao.crm.CustomerDao;
import com.epmet.dao.crm.CustomerRelationDao;
import com.epmet.dto.crm.CustomerRelationDTO;
import com.epmet.entity.crm.CustomerEntity; import com.epmet.entity.crm.CustomerEntity;
import com.epmet.service.crm.CustomerService; import com.epmet.service.crm.CustomerService;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
@ -17,6 +19,8 @@ public class CustomerServiceImpl implements CustomerService {
@Autowired @Autowired
private CustomerDao customerDao; private CustomerDao customerDao;
@Autowired
private CustomerRelationDao customerRelationDao;
@Override @Override
public List<CustomerEntity> listValidCustomersByCreateTime(Date createTimeFrom, Date createTimeTo) { public List<CustomerEntity> listValidCustomersByCreateTime(Date createTimeFrom, Date createTimeTo) {
@ -27,4 +31,13 @@ public class CustomerServiceImpl implements CustomerService {
public List<CustomerEntity> listValidCustomersByUpdatedTime(Date startTime, Date endTime) { public List<CustomerEntity> listValidCustomersByUpdatedTime(Date startTime, Date endTime) {
return customerDao.listValidCustomersByUpdateTime(startTime, endTime); return customerDao.listValidCustomersByUpdateTime(startTime, endTime);
} }
/**
* @Description 查询客户所属父客户信息
* @author sun
*/
@Override
public CustomerRelationDTO getByCustomerId(String customerId) {
return customerRelationDao.selectByCustomerId(customerId);
}
} }

29
epmet-module/data-statistical/data-statistical-server/src/main/java/com/epmet/service/impl/StatsUserServiceImpl.java

@ -3,16 +3,19 @@ package com.epmet.service.impl;
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSON;
import com.epmet.commons.tools.constant.NumConstant; import com.epmet.commons.tools.constant.NumConstant;
import com.epmet.commons.tools.exception.RenException;
import com.epmet.commons.tools.utils.DateUtils; import com.epmet.commons.tools.utils.DateUtils;
import com.epmet.constant.ProjectConstant; import com.epmet.constant.ProjectConstant;
import com.epmet.dao.stats.DataStatsDao; import com.epmet.dao.stats.DataStatsDao;
import com.epmet.dto.AgencySubTreeDto; import com.epmet.dto.AgencySubTreeDto;
import com.epmet.dto.CustomerAgencyDTO; import com.epmet.dto.CustomerAgencyDTO;
import com.epmet.dto.StatsFormDTO; import com.epmet.dto.StatsFormDTO;
import com.epmet.dto.crm.CustomerRelationDTO;
import com.epmet.dto.stats.form.GmUploadDataFormDTO; import com.epmet.dto.stats.form.GmUploadDataFormDTO;
import com.epmet.dto.stats.form.GmUploadEventFormDTO; import com.epmet.dto.stats.form.GmUploadEventFormDTO;
import com.epmet.dto.stats.user.result.UserStatisticalData; import com.epmet.dto.stats.user.result.UserStatisticalData;
import com.epmet.service.StatsUserService; import com.epmet.service.StatsUserService;
import com.epmet.service.crm.CustomerService;
import com.epmet.service.evaluationindex.screen.ScreenCustomerAgencyService; import com.epmet.service.evaluationindex.screen.ScreenCustomerAgencyService;
import com.epmet.service.stats.DimAgencyService; import com.epmet.service.stats.DimAgencyService;
import com.epmet.service.stats.DimCustomerService; import com.epmet.service.stats.DimCustomerService;
@ -26,6 +29,7 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils; import org.springframework.util.CollectionUtils;
import java.util.Calendar; import java.util.Calendar;
@ -60,6 +64,8 @@ public class StatsUserServiceImpl implements StatsUserService {
private ScreenCustomerAgencyService screenCustomerAgencyService; private ScreenCustomerAgencyService screenCustomerAgencyService;
@Autowired @Autowired
private DataStatsDao dataStatsDao; private DataStatsDao dataStatsDao;
@Autowired
private CustomerService customerService;
/** /**
@ -149,17 +155,19 @@ public class StatsUserServiceImpl implements StatsUserService {
* @author sun * @author sun
*/ */
@Override @Override
@Transactional(rollbackFor = Exception.class)
public void gmUploadEvent(GmUploadEventFormDTO formDTO) { public void gmUploadEvent(GmUploadEventFormDTO formDTO) {
//1.判断是否批量删除历史数据 //1.数据上报只涉及数据库部分数据,其他数据都是计算出来的,所以不存在删除历史数据,有就更新没有就新增
if (formDTO.getIsFirst()) { String customerId = formDTO.getDataList().get(0).getCustomerId();
int deleteNum;
do {
deleteNum = userService.delGmUploadEvent(formDTO.getCustomerId(), formDTO.getDateId());
} while (deleteNum > NumConstant.ZERO);
}
//2.查询当前客户index库组织信息供数据封装使用 //2.数据准备
List<CustomerAgencyDTO> agencyList = screenCustomerAgencyService.getByCustomerId(formDTO.getCustomerId()); //2-1.查询当前客户index库组织信息供数据封装使用
List<CustomerAgencyDTO> agencyList = screenCustomerAgencyService.getByCustomerId(customerId);
//2-2.查询客户所属父客户信息
CustomerRelationDTO crm = customerService.getByCustomerId(customerId);
if (null == crm) {
throw new RenException(String.format("未查询到子客户所属父客户信息,子客户Id->%s", customerId));
}
//3.分批处理上传数据 //3.分批处理上传数据
List<List<GmUploadEventFormDTO.DataList>> partition = ListUtils.partition(formDTO.getDataList(), NumConstant.ONE_HUNDRED); List<List<GmUploadEventFormDTO.DataList>> partition = ListUtils.partition(formDTO.getDataList(), NumConstant.ONE_HUNDRED);
@ -175,6 +183,8 @@ public class StatsUserServiceImpl implements StatsUserService {
} }
}); });
if (bl.get()) { if (bl.get()) {
m.setSourceType("external");
m.setParentCustomerId(crm.getParentCustomerId());
m.setGridPids(gridPids.toString()); m.setGridPids(gridPids.toString());
m.setPatrolTotal(NumConstant.ZERO); m.setPatrolTotal(NumConstant.ZERO);
m.setTotalTime(NumConstant.ZERO); m.setTotalTime(NumConstant.ZERO);
@ -197,6 +207,7 @@ public class StatsUserServiceImpl implements StatsUserService {
* @author sun * @author sun
*/ */
@Override @Override
@Transactional(rollbackFor = Exception.class)
public void gmUploadData(GmUploadDataFormDTO formDTO) { public void gmUploadData(GmUploadDataFormDTO formDTO) {
//1.判断是否批量删除历史数据 //1.判断是否批量删除历史数据
if (formDTO.getIsFirst()) { if (formDTO.getIsFirst()) {

11
epmet-module/data-statistical/data-statistical-server/src/main/resources/mapper/crm/CustomerRelationDao.xml

@ -39,4 +39,15 @@
<select id="selectSubCustomer" resultType="com.epmet.entity.crm.CustomerRelationEntity"> <select id="selectSubCustomer" resultType="com.epmet.entity.crm.CustomerRelationEntity">
SELECT * FROM customer_relation WHERE DEL_FLAG = 0 AND PARENT_CUSTOMER_ID = #{customerId} SELECT * FROM customer_relation WHERE DEL_FLAG = 0 AND PARENT_CUSTOMER_ID = #{customerId}
</select> </select>
<select id="selectByCustomerId" resultType="com.epmet.dto.crm.CustomerRelationDTO">
SELECT
*
FROM
customer_relation
WHERE
del_flag = '0'
AND customer_id = #{customerId}
</select>
</mapper> </mapper>

7
epmet-module/data-statistical/data-statistical-server/src/main/resources/mapper/user/UserDao.xml

@ -641,7 +641,9 @@
INSERT INTO stats_staff_patrol_record_daily INSERT INTO stats_staff_patrol_record_daily
( (
id, id,
source_type,
customer_id, customer_id,
source_customer_id,
date_id, date_id,
week_id, week_id,
month_id, month_id,
@ -667,6 +669,8 @@
<foreach collection="list" item="i" separator=","> <foreach collection="list" item="i" separator=",">
( (
REPLACE(UUID(), '-', ''), REPLACE(UUID(), '-', ''),
#{i.sourceType},
#{i.parentCustomerId},
#{i.customerId}, #{i.customerId},
#{i.dateId}, #{i.dateId},
#{i.weekId}, #{i.weekId},
@ -692,6 +696,9 @@
</foreach> </foreach>
ON DUPLICATE KEY ON DUPLICATE KEY
UPDATE UPDATE
source_type = values(source_type),
customer_id = values(customer_id),
source_customer_id = values(source_customer_id),
report_project_count = values(report_project_count), report_project_count = values(report_project_count),
updated_by = 'BASE_REPORT', updated_by = 'BASE_REPORT',
updated_time = NOW() updated_time = NOW()

Loading…
Cancel
Save