using System;
using SqlSugar;
using Infrastructure.Attribute;
using ZR.Model;
using ZR.Model.Dto;
using ZR.Model.Models;
using ZR.Repository;
using ZR.Service.Business.IBusinessService;
using System.Linq;
using Infrastructure;
using System.Collections.Generic;
namespace ZR.Service.Business
{
///
/// 接口管理/SAP关键件清单记录表Service业务层处理
///
/// @author admin
/// @date 2023-05-05
///
[AppService(ServiceType = typeof(ISapBomRecordService), ServiceLifetime = LifeTime.Transient)]
public class SapBomRecordService : BaseService, ISapBomRecordService
{
#region 业务逻辑代码
///
/// 查询接口管理/SAP关键件清单记录表列表
///
///
///
public PagedInfo GetList(SapBomRecordQueryDto parm)
{
//开始拼装查询条件
var predicate = Expressionable.Create();
if (parm.BeginTime != null && parm.EndTime != null)
{
parm.BeginTime = DateTimeHelper.GetBeginTime(parm.BeginTime, -1);
parm.EndTime = DateTimeHelper.GetBeginTime(parm.EndTime, 1);
predicate.And(d => d.CreateTime >= parm.BeginTime && d.CreateTime <= parm.EndTime);
}
predicate.AndIF(!string.IsNullOrEmpty(parm.BomNo), d => d.BomNo.Contains(parm.BomNo));
predicate.AndIF(!string.IsNullOrEmpty(parm.MaterialCode), d => d.MaterialCode.Contains(parm.MaterialCode));
predicate.AndIF(!string.IsNullOrEmpty(parm.MaterialName), d => d.MaterialName.Contains(parm.MaterialName));
predicate.AndIF(!string.IsNullOrEmpty(parm.MaterialSpec), d => d.MaterialSpec.Contains(parm.MaterialSpec));
predicate.AndIF(!string.IsNullOrEmpty(parm.Category), d => d.Category == parm.Category);
predicate.AndIF(parm.KeyFlag != null, d => d.KeyFlag == parm.KeyFlag);
//搜索条件查询语法参考Sqlsugar
var response = Queryable()
.Where(predicate.ToExpression())
.ToPage(parm);
return response;
}
///
/// 添加接口管理/SAP关键件清单记录表
///
///
///
public int AddSapBomRecord(SapBomRecord model)
{
return Add(model, true);
}
///
/// 修改接口管理/SAP关键件清单记录表
///
///
///
public int UpdateSapBomRecord(SapBomRecord model)
{
//var response = Update(w => w.Id == model.Id, it => new SapBomRecord()
//{
// BomNo = model.BomNo,
// EquipmentName = model.EquipmentName,
// MakeBy = model.MakeBy,
// MakeTime = model.MakeTime,
// Category = model.Category,
// MaterialCode = model.MaterialCode,
// MaterialName = model.MaterialName,
// MaterialSpec = model.MaterialSpec,
// KeyFlag = model.KeyFlag,
// Qty = model.Qty,
// AssembleQty = model.AssembleQty,
// Result = model.Result,
// UpdateBy = model.UpdateBy,
// UpdateTime = model.UpdateTime,
// Remark = model.Remark,
//});
//return response;
return Update(model, true);
}
///
/// 清空接口管理/SAP关键件清单记录表
///
///
public void TruncateSapBomRecord()
{
Truncate();
}
///
/// 导入数据
///
///
///
public string ImportDatas(List list)
{
var x = Context.Storageable(list)
.SplitInsert(it => !it.Any())
.ToStorage();
var result = x.AsInsertable.ExecuteCommand();//插入可插入部分;
string msg = string.Format(" 插入{0} 更新{1} 错误数据{2} 不计算数据{3} 删除数据{4},总共{5}",
x.InsertList.Count,
x.UpdateList.Count,
x.ErrorList.Count,
x.IgnoreList.Count,
x.DeleteList.Count,
x.TotalList.Count);
//输出统计
Console.WriteLine(msg);
//输出错误信息
foreach (var item in x.ErrorList)
{
Console.WriteLine("关键件清单ID:" + item.Item.Id + " : " + item.StorageMessage);
}
return msg;
}
#endregion
}
}