using DOAN.Common; using DOAN.Model.BZFM; using DOAN.Model.BZFM.Dto; using DOAN.Model.System; using DOAN.Repository; using DOAN.Service.BZFM.IBZFMService; using Infrastructure; using Infrastructure.Attribute; using Infrastructure.Extensions; namespace DOAN.Service.BZFM { /// /// 物料表Service业务层处理 /// [AppService(ServiceType = typeof(IMmMaterialService), ServiceLifetime = LifeTime.Transient)] public class MmMaterialService : BaseService, IMmMaterialService { /// /// 查询物料表列表 /// /// /// public PagedInfo GetList(MmMaterialQueryDto parm) { var predicate = QueryExp(parm); var response = Queryable() .Where(predicate.ToExpression()) .OrderBy(it => it.Type) .ToPage(parm); return response; } /// /// 获取详情 /// /// /// public MmMaterial GetInfo(int Id) { var response = Queryable() .Where(x => x.Id == Id) .First(); return response; } /// /// 添加物料表 /// /// /// public MmMaterial AddMmMaterial(MmMaterial model) { return Insertable(model).ExecuteReturnEntity(); } /// /// 修改物料表 /// /// /// public int UpdateMmMaterial(MmMaterial model) { return Update(model, true); } /// /// 查询导出表达式 /// /// /// private static Expressionable QueryExp(MmMaterialQueryDto parm) { var predicate = Expressionable.Create() .AndIF(!string.IsNullOrEmpty(parm.CategoryCode), m => m.CategoryCode.Contains(parm.CategoryCode)) .AndIF(!string.IsNullOrEmpty(parm.MaterialName), m => m.MaterialName.Contains(parm.MaterialName)) .AndIF(!string.IsNullOrEmpty(parm.MaterialCode), m => m.MaterialCode.Contains(parm.MaterialCode)) .AndIF(!string.IsNullOrEmpty(parm.Specification), m => m.Specification.Contains(parm.Specification)) .AndIF(!string.IsNullOrEmpty(parm.Type), m => m.Type.Contains(parm.Type)) .AndIF(!string.IsNullOrEmpty(parm.Status), m => m.Status == parm.Status); return predicate; } /// /// 获取物料类别下拉框 /// /// /// /// public List GetMmMaterialCategoryOptions(MmMaterialCategoryDto parm) { try { return Context.Queryable() .WhereIF(!string.IsNullOrEmpty(parm.CategoryCode),it => it.CategoryCode.Contains(parm.CategoryCode)) .WhereIF(!string.IsNullOrEmpty(parm.CategoryName), it => it.CategoryName.Contains(parm.CategoryName)) .Select(it => new MmMaterialCategoryOptionsDto { Label = it.CategoryName, Value = it.CategoryCode } ).ToList(); } catch (Exception) { // TODO 处理错误日志 throw; } } /// /// 导入数据 /// /// /// public (string, object, object) Importmaterial(List material) { material.ForEach(x => { x.CreatedTime = DateTime.Now; x.Status = "启用"; x.MaterialCode = ""; x.MaterialName = "E10ADC3949BA59ABBE56E057F20F883E"; //x.Remark = x.Remark.IsEmpty() ? "数据导入" : x.Remark; }); var x = Context.Storageable(material) .SplitInsert(it => !it.Any()) .SplitIgnore(it => it.Item.MaterialCode == GlobalConstant.AdminRole) .SplitError(x => x.Item.MaterialCode.IsEmpty(), "物料编码不能为空") .SplitError(x => !Tools.CheckUserName(x.Item.MaterialCode), "物料编码不符合规范") .WhereColumns(it => it.MaterialCode)//如果不是主键可以这样实现(多字段it=>new{it.x1,it.x2}) .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("MaterialCode为" + item.Item.MaterialCode + " : " + item.StorageMessage); } foreach (var item in x.IgnoreList) { Console.WriteLine("MaterialCode为" + item.Item.MaterialCode + " : " + item.StorageMessage); } return (msg, x.ErrorList, x.IgnoreList); } } }