新增半月报功能

This commit is contained in:
xy
2025-07-04 10:19:24 +08:00
parent 0b32c09fdb
commit 186eec4f7e
11 changed files with 182 additions and 89 deletions

View File

@@ -0,0 +1,26 @@
package com.njcn.access.api;
import com.njcn.access.api.fallback.CsLineLatestDataClientFallbackFactory;
import com.njcn.access.pojo.po.CsLineLatestData;
import com.njcn.common.pojo.constant.ServerInfo;
import com.njcn.common.pojo.response.HttpResult;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import java.util.List;
/**
* @author xy
*/
@FeignClient(value = ServerInfo.ACCESS_BOOT, path = "/csLineLatestData", fallbackFactory = CsLineLatestDataClientFallbackFactory.class,contextId = "csLineLatestData")
public interface CsLineLatestDataFeignClient {
@PostMapping("/add")
HttpResult<String> addData(@RequestBody CsLineLatestData csLineLatestData);
@PostMapping("/list")
HttpResult<List<CsLineLatestData>> listData();
}

View File

@@ -0,0 +1,44 @@
package com.njcn.access.api.fallback;
import com.njcn.access.api.CsLineLatestDataFeignClient;
import com.njcn.access.pojo.po.CsLineLatestData;
import com.njcn.common.pojo.enums.response.CommonResponseEnum;
import com.njcn.common.pojo.exception.BusinessException;
import com.njcn.common.pojo.response.HttpResult;
import feign.hystrix.FallbackFactory;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
import java.util.List;
/**
* @author xy
*/
@Slf4j
@Component
public class CsLineLatestDataClientFallbackFactory implements FallbackFactory<CsLineLatestDataFeignClient> {
@Override
public CsLineLatestDataFeignClient create(Throwable cause) {
//判断抛出异常是否为解码器抛出的业务异常
Enum<?> exceptionEnum = CommonResponseEnum.SERVICE_FALLBACK;
if (cause.getCause() instanceof BusinessException) {
BusinessException businessException = (BusinessException) cause.getCause();
}
Enum<?> finalExceptionEnum = exceptionEnum;
return new CsLineLatestDataFeignClient() {
@Override
public HttpResult<String> addData(CsLineLatestData csLineLatestData) {
log.error("{}异常,降级处理,异常为:{}","新增治理设备最近数据时间",cause.toString());
throw new BusinessException(finalExceptionEnum);
}
@Override
public HttpResult<List<CsLineLatestData>> listData() {
log.error("{}异常,降级处理,异常为:{}","查询整体数据",cause.toString());
throw new BusinessException(finalExceptionEnum);
}
};
}
}

View File

@@ -2,6 +2,7 @@ package com.njcn.access.pojo.po;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.github.jeffreyning.mybatisplus.anno.MppMultiId;
import lombok.Getter;
import lombok.Setter;
@@ -14,35 +15,26 @@ import java.time.LocalDateTime;
* </p>
*
* @author xy
* @since 2025-06-26
* @since 2025-07-03
*/
@Getter
@Setter
@TableName("cs_line_run_data")
public class CsLineRunData implements Serializable {
@TableName("cs_line_latest_data")
public class CsLineLatestData implements Serializable{
private static final long serialVersionUID = 1L;
/**
* 监测点id
*/
@MppMultiId(value = "line_id")
private String lineId;
/**
* 子模块编号id(没有子模块则为0)
*/
private Integer moduleId;
/**
* 最新数据时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime timeId;
/**
* 子模块通讯状态(0离线 1连接)
*/
private Integer runState;
}