出库与库存查询接口及DTO结构优化

- 出库记录表查询接口由 GET 改为 POST,支持更复杂参数
- 新增出库记录接口参数由 FromBody 改为 FromQuery
- MmInventoryDto 增加 BatchNo 字段,支持按批次号查询
- MmRecordOutboundDto 的 CreatedTime 改为时间区间数组
- 服务层查询逻辑支持批次号和时间区间查询
- 优化 using 引用顺序,提升代码可维护性
This commit is contained in:
2026-01-04 15:08:36 +08:00
parent 28dcf5678c
commit 062dcf0488
5 changed files with 27 additions and 9 deletions

View File

@@ -29,7 +29,7 @@ namespace DOAN.Admin.WebApi.Controllers.BZFM
/// </summary> /// </summary>
/// <param name="parm"></param> /// <param name="parm"></param>
/// <returns></returns> /// <returns></returns>
[HttpGet("list")] [HttpPost("list")]
[ActionPermissionFilter(Permission = "mmrecordoutbound:list")] [ActionPermissionFilter(Permission = "mmrecordoutbound:list")]
public IActionResult QueryMmRecordOutbound([FromQuery] MmRecordOutboundQueryDto parm) public IActionResult QueryMmRecordOutbound([FromQuery] MmRecordOutboundQueryDto parm)
{ {
@@ -43,7 +43,7 @@ namespace DOAN.Admin.WebApi.Controllers.BZFM
/// </summary> /// </summary>
/// <param name="Id"></param> /// <param name="Id"></param>
/// <returns></returns> /// <returns></returns>
[HttpGet("{Id}")] [HttpPost("{Id}")]
[ActionPermissionFilter(Permission = "mmrecordoutbound:query")] [ActionPermissionFilter(Permission = "mmrecordoutbound:query")]
public IActionResult GetMmRecordOutbound(int Id) public IActionResult GetMmRecordOutbound(int Id)
{ {
@@ -60,7 +60,7 @@ namespace DOAN.Admin.WebApi.Controllers.BZFM
[HttpPost] [HttpPost]
[ActionPermissionFilter(Permission = "mmrecordoutbound:add")] [ActionPermissionFilter(Permission = "mmrecordoutbound:add")]
[Log(Title = "出库记录表", BusinessType = BusinessType.INSERT)] [Log(Title = "出库记录表", BusinessType = BusinessType.INSERT)]
public IActionResult AddMmRecordOutbound([FromBody] MmRecordOutboundDto parm) public IActionResult AddMmRecordOutbound([FromQuery] MmRecordOutboundDto parm)
{ {
var modal = parm.Adapt<MmRecordOutbound>().ToCreate(HttpContext); var modal = parm.Adapt<MmRecordOutbound>().ToCreate(HttpContext);

View File

@@ -10,6 +10,8 @@ namespace DOAN.Model.BZFM.Dto
public string MaterialCode { get; set; } public string MaterialCode { get; set; }
public string WarehouseName { get; set; } public string WarehouseName { get; set; }
public string BatchNo { get; set; }
} }
/// <summary> /// <summary>

View File

@@ -10,7 +10,7 @@ namespace DOAN.Model.BZFM.Dto
public string OutboundNo { get; set; } public string OutboundNo { get; set; }
public DateTime? CreatedTime { get; set; } public DateTime[] CreatedTime { get; set; } = new DateTime[2];
public string TransactionType { get; set; } public string TransactionType { get; set; }
} }

View File

@@ -76,6 +76,7 @@ namespace DOAN.Service.BZFM
.AndIF(!string.IsNullOrEmpty(parm.WarehouseCode), m => m.WarehouseCode.Contains(parm.WarehouseCode)) .AndIF(!string.IsNullOrEmpty(parm.WarehouseCode), m => m.WarehouseCode.Contains(parm.WarehouseCode))
.AndIF(!string.IsNullOrEmpty(parm.MaterialCode), m => m.MaterialCode.Contains(parm.MaterialCode)) .AndIF(!string.IsNullOrEmpty(parm.MaterialCode), m => m.MaterialCode.Contains(parm.MaterialCode))
.AndIF(!string.IsNullOrEmpty(parm.WarehouseName), m => m.WarehouseName.Contains(parm.WarehouseName)) .AndIF(!string.IsNullOrEmpty(parm.WarehouseName), m => m.WarehouseName.Contains(parm.WarehouseName))
.AndIF(!string.IsNullOrEmpty(parm.BatchNo), m => m.BatchNo.Contains(parm.BatchNo))
; ;
return predicate; return predicate;

View File

@@ -1,9 +1,10 @@
using Infrastructure.Attribute;
using Infrastructure.Extensions;
using DOAN.Model.BZFM.Dto;
using DOAN.Model.BZFM; using DOAN.Model.BZFM;
using DOAN.Model.BZFM.Dto;
using DOAN.Repository; using DOAN.Repository;
using DOAN.Service.BZFM.IBZFMService; using DOAN.Service.BZFM.IBZFMService;
using Infrastructure.Attribute;
using Infrastructure.Converter;
using Infrastructure.Extensions;
namespace DOAN.Service.BZFM namespace DOAN.Service.BZFM
{ {
@@ -71,12 +72,26 @@ namespace DOAN.Service.BZFM
/// <returns></returns> /// <returns></returns>
private static Expressionable<MmRecordOutbound> QueryExp(MmRecordOutboundQueryDto parm) private static Expressionable<MmRecordOutbound> QueryExp(MmRecordOutboundQueryDto parm)
{ {
if (parm.CreatedTime != null && parm.CreatedTime.Length > 0)
{
parm.CreatedTime[0] = DOANConvertDate.ConvertLocalDate(parm.CreatedTime[0]);
parm.CreatedTime[1] = DOANConvertDate.ConvertLocalDate(parm.CreatedTime[1]);
parm.CreatedTime[0] = parm.CreatedTime[0].Date;
parm.CreatedTime[1] = parm.CreatedTime[1].Date;
}
var predicate = Expressionable.Create<MmRecordOutbound>() var predicate = Expressionable.Create<MmRecordOutbound>()
.AndIF(!string.IsNullOrEmpty(parm.MaterialCode), it => it.MaterialCode.Contains(parm.MaterialCode)) .AndIF(!string.IsNullOrEmpty(parm.MaterialCode), it => it.MaterialCode.Contains(parm.MaterialCode))
.AndIF(!string.IsNullOrEmpty(parm.OutboundNo), it => it.OutboundNo.Contains(parm.OutboundNo)) .AndIF(!string.IsNullOrEmpty(parm.OutboundNo), it => it.OutboundNo.Contains(parm.OutboundNo))
.AndIF(!string.IsNullOrEmpty(parm.TransactionType), it => it.TransactionType.Contains(parm.TransactionType)) .AndIF(!string.IsNullOrEmpty(parm.TransactionType), it => it.TransactionType.Contains(parm.TransactionType))
.AndIF(parm.CreatedTime > DateTime.MinValue, it => it.CreatedTime < parm.CreatedTime) .AndIF(
; parm.CreatedTime != null && parm.CreatedTime[0] > DateTime.MinValue,
it => it.CreatedTime >= parm.CreatedTime[0]
)
.AndIF(
parm.CreatedTime != null && parm.CreatedTime[1] > DateTime.MinValue,
it => it.CreatedTime <= parm.CreatedTime[1]
);
;
return predicate; return predicate;
} }