Files
kunshan-bzfm-mes-backend/DOAN.Service/MES/Material/MmLocationService.cs
Carl 3fdad62fb7 增强各业务表查询DTO及Service的多条件查询支持
本次提交为库位、入库、出库、出入库类别等业务表的查询DTO新增了多个查询字段,并在对应Service层的QueryExp方法中实现了这些字段的动态拼接查询。调整后支持按编码、名称、操作员等多条件模糊筛选,提升了查询灵活性和前端多条件检索能力。同时优化了部分using引用顺序。
2025-12-30 17:26:11 +08:00

81 lines
2.4 KiB
C#

using Infrastructure.Attribute;
using Infrastructure.Extensions;
using DOAN.Model.BZFM.Dto;
using DOAN.Model.BZFM;
using DOAN.Repository;
using DOAN.Service.BZFM.IBZFMService;
namespace DOAN.Service.BZFM
{
/// <summary>
/// 库位表Service业务层处理
/// </summary>
[AppService(ServiceType = typeof(IMmLocationService), ServiceLifetime = LifeTime.Transient)]
public class MmLocationService : BaseService<MmLocation>, IMmLocationService
{
/// <summary>
/// 查询库位表列表
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
public PagedInfo<MmLocationDto> GetList(MmLocationQueryDto parm)
{
var predicate = QueryExp(parm);
var response = Queryable()
.Where(predicate.ToExpression())
.ToPage<MmLocation, MmLocationDto>(parm);
return response;
}
/// <summary>
/// 获取详情
/// </summary>
/// <param name="Id"></param>
/// <returns></returns>
public MmLocation GetInfo(int Id)
{
var response = Queryable()
.Where(x => x.Id == Id)
.First();
return response;
}
/// <summary>
/// 添加库位表
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public MmLocation AddMmLocation(MmLocation model)
{
return Insertable(model).ExecuteReturnEntity();
}
/// <summary>
/// 修改库位表
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public int UpdateMmLocation(MmLocation model)
{
return Update(model, true);
}
/// <summary>
/// 查询导出表达式
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
private static Expressionable<MmLocation> QueryExp(MmLocationQueryDto parm)
{
var predicate = Expressionable.Create<MmLocation>()
.AndIF(!string.IsNullOrEmpty(parm.LocationCode), it => it.LocationCode.Contains(parm.LocationCode))
.AndIF(!string.IsNullOrEmpty(parm.WarehouseCode), it => it.WarehouseCode.Contains(parm.WarehouseCode));
return predicate;
}
}
}