feat(wms): 添加钢卷库区操作记录导出功能以及优化查询速率

- 在服务接口中新增 exportBySecondWarehouseIdAndTimeRange 方法用于导出功能
- 在控制器中新增 exportByWarehouseAndTime 接口支持报表导出
- 在映射器中新增 selectVoListWithJoin 查询方法优化关联查询
- 在 XML 映射文件中新增完整的关联查询 SQL 和结果映射配置
- 在服务实现类中重构查询逻辑使用新的关联查询方法
- 新增 WmsCoilWarehouseOperationLogExportVo 导出数据对象
- 实现导出逻辑将操作记录转换为 Excel 格式并支持多表关联
- 添加状态描述转换方法支持中文显示
- 更新 VO 类继承 BaseEntity 基础实体类
This commit is contained in:
2026-03-24 10:35:57 +08:00
parent 1fc85c990f
commit ad100083ed
7 changed files with 382 additions and 40 deletions

View File

@@ -19,6 +19,7 @@ import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.domain.vo.WmsCoilWarehouseOperationLogVo;
import com.klp.domain.vo.WmsCoilWarehouseOperationLogExportVo;
import com.klp.domain.bo.WmsCoilWarehouseOperationLogBo;
import com.klp.service.IWmsCoilWarehouseOperationLogService;
import com.klp.common.core.page.TableDataInfo;
@@ -151,4 +152,26 @@ public class WmsCoilWarehouseOperationLogController extends BaseController {
@RequestParam(required = false) Date endTime) {
return R.ok(iWmsCoilWarehouseOperationLogService.queryByCoilId(coilId, operationType, inOutType, startTime, endTime));
}
/**
* 导出钢卷库区操作记录(报表导出)
*
* @param secondWarehouseId 二级库区ID
* @param operationType 操作类型
* @param inOutType 出入库类型
* @param startTime 开始时间
* @param endTime 结束时间
*/
@Log(title = "钢卷库区操作记录导出", businessType = BusinessType.EXPORT)
@PostMapping("/exportByWarehouseAndTime")
public void exportByWarehouseAndTime(
@RequestParam Long secondWarehouseId,
@RequestParam(required = false) Integer operationType,
@RequestParam(required = false) Integer inOutType,
@RequestParam(required = false) Date startTime,
@RequestParam(required = false) Date endTime,
HttpServletResponse response) {
List<WmsCoilWarehouseOperationLogExportVo> list = iWmsCoilWarehouseOperationLogService.exportBySecondWarehouseIdAndTimeRange(secondWarehouseId, operationType, inOutType, startTime, endTime);
ExcelUtil.exportExcel(list, "钢卷库区操作记录导出", WmsCoilWarehouseOperationLogExportVo.class, response);
}
}