本次提交为库位、入库、出库、出入库类别等业务表的查询DTO新增了多个查询字段,并在对应Service层的QueryExp方法中实现了这些字段的动态拼接查询。调整后支持按编码、名称、操作员等多条件模糊筛选,提升了查询灵活性和前端多条件检索能力。同时优化了部分using引用顺序。
84 lines
2.6 KiB
C#
84 lines
2.6 KiB
C#
using DOAN.Model.BZFM;
|
|
using DOAN.Model.BZFM.Dto;
|
|
using DOAN.Repository;
|
|
using DOAN.Service.BZFM.IBZFMService;
|
|
using Infrastructure.Attribute;
|
|
using Infrastructure.Extensions;
|
|
using Microsoft.IdentityModel.Tokens;
|
|
|
|
namespace DOAN.Service.BZFM
|
|
{
|
|
/// <summary>
|
|
/// 入库记录表Service业务层处理
|
|
/// </summary>
|
|
[AppService(ServiceType = typeof(IMmRecordInboundService), ServiceLifetime = LifeTime.Transient)]
|
|
public class MmRecordInboundService : BaseService<MmRecordInbound>, IMmRecordInboundService
|
|
{
|
|
/// <summary>
|
|
/// 查询入库记录表列表
|
|
/// </summary>
|
|
/// <param name="parm"></param>
|
|
/// <returns></returns>
|
|
public PagedInfo<MmRecordInboundDto> GetList(MmRecordInboundQueryDto parm)
|
|
{
|
|
var predicate = QueryExp(parm);
|
|
|
|
var response = Queryable()
|
|
.Where(predicate.ToExpression())
|
|
.ToPage<MmRecordInbound, MmRecordInboundDto>(parm);
|
|
|
|
return response;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 获取详情
|
|
/// </summary>
|
|
/// <param name="Id"></param>
|
|
/// <returns></returns>
|
|
public MmRecordInbound GetInfo(int Id)
|
|
{
|
|
var response = Queryable()
|
|
.Where(x => x.Id == Id)
|
|
.First();
|
|
|
|
return response;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 添加入库记录表
|
|
/// </summary>
|
|
/// <param name="model"></param>
|
|
/// <returns></returns>
|
|
public MmRecordInbound AddMmRecordInbound(MmRecordInbound model)
|
|
{
|
|
return Insertable(model).ExecuteReturnEntity();
|
|
}
|
|
|
|
/// <summary>
|
|
/// 修改入库记录表
|
|
/// </summary>
|
|
/// <param name="model"></param>
|
|
/// <returns></returns>
|
|
public int UpdateMmRecordInbound(MmRecordInbound model)
|
|
{
|
|
return Update(model, true);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 查询导出表达式
|
|
/// </summary>
|
|
/// <param name="parm"></param>
|
|
/// <returns></returns>
|
|
private static Expressionable<MmRecordInbound> QueryExp(MmRecordInboundQueryDto parm)
|
|
{
|
|
var predicate = Expressionable.Create<MmRecordInbound>()
|
|
.AndIF(!string.IsNullOrEmpty(parm.SupplierCode), it => it.SupplierCode.Contains(parm.SupplierCode))
|
|
.AndIF(!string.IsNullOrEmpty(parm.Operator), it => it.Operator.Contains(parm.Operator))
|
|
//.AndIF(!string.IsNullOrEmpty(parm.CreatedTime), it => it.CreatedTime.Contains(parm.CreatedTime))
|
|
;
|
|
|
|
return predicate;
|
|
}
|
|
}
|
|
} |