using MES.Service.DB; using MES.Service.Dto.webApi; using MES.Service.Modes; using SqlSugar; namespace MES.Service.service.BasicData; public class SalesOrderManager : Repository { //当前类已经继承了 Repository 增、删、查、改的方法 //这里面写的代码不会给覆盖,如果要重新生成请删除 SalesOrderManager.cs #region 教学方法 /// /// 仓储方法满足不了复杂业务需求,业务代码请在这里面定义方法 /// public void Study() { /*********查询*********/ var data1 = base.GetById(1); //根据ID查询 var data2 = base.GetList(); //查询所有 var data3 = base.GetList(it => 1 == 1); //根据条件查询 //var data4 = base.GetSingle(it => 1 == 1);//根据条件查询一条,如果超过一条会报错 var p = new PageModel { PageIndex = 1, PageSize = 2 }; // 分页查询 var data5 = base.GetPageList(it => 1 == 1, p); Console.Write(p.TotalCount); //返回总数 var data6 = base.GetPageList(it => 1 == 1, p, it => SqlFunc.GetRandom()); // 分页查询加排序 Console.Write(p.TotalCount); //返回总数 var conModels = new List(); //组装条件查询作为条件实现 分页查询加排序 conModels.Add(new ConditionalModel { FieldName = typeof(SalesOrder).GetProperties()[0].Name, ConditionalType = ConditionalType.Equal, FieldValue = "1" }); //id=1 var data7 = base.GetPageList(conModels, p, it => SqlFunc.GetRandom()); AsQueryable().Where(x => 1 == 1) .ToList(); //支持了转换成queryable,我们可以用queryable实现复杂功能 /*********插入*********/ var insertData = new SalesOrder(); //测试参数 var insertArray = new[] { insertData }; base.Insert(insertData); //插入 base.InsertRange(insertArray); //批量插入 var id = base.InsertReturnIdentity(insertData); //插入返回自增列 AsInsertable(insertData).ExecuteCommand(); //我们可以转成 Insertable实现复杂插入 /*********更新*********/ var updateData = new SalesOrder(); //测试参数 var updateArray = new[] { updateData }; //测试参数 base.Update(updateData); //根据实体更新 base.UpdateRange(updateArray); //批量更新 //base.Update(it => new SalesOrder() { ClassName = "a", CreateTime = DateTime.Now }, it => it.id==1);// 只更新ClassName列和CreateTime列,其它列不更新,条件id=1 AsUpdateable(updateData).ExecuteCommand(); //转成Updateable可以实现复杂的插入 /*********删除*********/ var deldata = new SalesOrder(); //测试参数 base.Delete(deldata); //根据实体删除 base.DeleteById(1); //根据主键删除 base.DeleteById(new[] { 1, 2 }); //根据主键数组删除 base.Delete(it => 1 == 2); //根据条件删除 AsDeleteable().Where(it => 1 == 2) .ExecuteCommand(); //转成Deleteable实现复杂的操作 } #endregion private readonly SalesOrderDetailManager salesOrderDetailManager = new(); // Save 方法用于保存单个 销售订单(SalesOrder) 记录,根据类型执行不同的操作 public bool Save(SalesOrders salesOrders) { var salesOrdersErpSalesOrder = salesOrders.ErpSalesOrder; var mesSalesOrders = GetMesSalesOrder(salesOrdersErpSalesOrder); var mesSalesOrderDetail = GetErpSalesOrderDetail(salesOrders.ErpSalesOrderDetails,salesOrdersErpSalesOrder.Type); return UseTransaction(db => { switch (salesOrdersErpSalesOrder.Type) { case "3": return UpdateData(db, mesSalesOrders, mesSalesOrderDetail) ? 1 : 0; case "2": case "4": case "5": case "B": return SaveOrUpdateData(db, mesSalesOrders, mesSalesOrderDetail) ? 1 : 0; default: throw new NotImplementedException( $"type没有{salesOrdersErpSalesOrder.Type}这个类型"); } }) > 0; } // 更新数据的方法(单纯的删除) private bool UpdateData(SqlSugarScope db, SalesOrder salesOrder, List salesOrderDetails) { var decimals = salesOrderDetails.Select(s => s.Id).ToArray(); var update = base.DeleteById(salesOrder.Id); var insertOrUpdate = db .Deleteable().In(decimals) .ExecuteCommand() > 0; if (update && insertOrUpdate) return true; throw new NotImplementedException("删除失败"); } // 插入或更新数据的方法 private bool SaveOrUpdateData(SqlSugarScope db, SalesOrder salesOrder, List salesOrderDetails) { if (salesOrder.Id != null) base.DeleteById(salesOrder.Id); if (salesOrderDetails.Count > 0) db.Deleteable() .Where(s => s.ErpId == salesOrder.Id).ExecuteCommand(); var orUpdate = base.Insert(salesOrder); var baOrUpdate = salesOrderDetailManager.InsertRange(salesOrderDetails); if (orUpdate && baOrUpdate) return true; throw new NotImplementedException("插入或更新失败"); } // 批量保存记录的方法 public bool SaveList(List salesOrders) { var result = salesOrders.Select(Save).ToList(); return result.All(b => b); } // 将 ErpSalesOrder 对象转换为 SalesOrder 对象的方法 public SalesOrder GetMesSalesOrder(ErpSalesOrder erpSalesOrder) { var eid = Convert.ToDecimal(erpSalesOrder.Id); var MesSalesOrder = new SalesOrder(); var single = base.GetSingle(it => it.Id == eid); if (single != null) MesSalesOrder.Id = single.Id; MesSalesOrder.ErpId = Convert.ToDecimal(erpSalesOrder.ErpID); MesSalesOrder.BillNo = erpSalesOrder.FBillNo; MesSalesOrder.BillTypeId = erpSalesOrder.FBillTypeID; MesSalesOrder.DocumentStatus = erpSalesOrder.FDocumentStatus; if (erpSalesOrder.FDate != null) MesSalesOrder.FDate = DateTime.ParseExact(erpSalesOrder.FDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesOrder.BusinessType = erpSalesOrder.FBusinessType; MesSalesOrder.HeadDeliveryWay = erpSalesOrder.FHeadDeliveryWay; MesSalesOrder.CloseStatus = erpSalesOrder.FCloseStatus; MesSalesOrder.HeadLocId = erpSalesOrder.FHEADLOCID; MesSalesOrder.CustId = erpSalesOrder.FCustId; MesSalesOrder.CloseStatus = erpSalesOrder.FCloseStatus; MesSalesOrder.SaleDeptId = erpSalesOrder.FSaleDeptId; MesSalesOrder.SalerId = erpSalesOrder.FSalerId; MesSalesOrder.ChangeReason = erpSalesOrder.FChangeReason; MesSalesOrder.Note = erpSalesOrder.FNote; MesSalesOrder.SettleId = erpSalesOrder.FSettleId; MesSalesOrder.LinkMan = erpSalesOrder.FLinkMan; MesSalesOrder.ChargeId = erpSalesOrder.FChargeId; MesSalesOrder.LinkPhone = erpSalesOrder.FLinkPhone; MesSalesOrder.CreatorId = erpSalesOrder.FCreatorId; if (erpSalesOrder.FCreateDate != null) MesSalesOrder.CreateDate = DateTime.ParseExact(erpSalesOrder.FCreateDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesOrder.ModifierId = erpSalesOrder.FModifierId; if (erpSalesOrder.FModifyDate != null) MesSalesOrder.ModifyDate = DateTime.ParseExact(erpSalesOrder.FModifyDate, "yyyy-MM-dd HH:mm:ss", null); if (erpSalesOrder.FApproveDate != null) MesSalesOrder.ApproveDate = DateTime.ParseExact(erpSalesOrder.FApproveDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesOrder.CloserId = erpSalesOrder.FCloserId; if (erpSalesOrder.FCloseDate != null) MesSalesOrder.CloseDate = DateTime.ParseExact(erpSalesOrder.FCloseDate, "yyyy-MM-dd HH:mm:ss", null); if (erpSalesOrder.FChangeDate != null) MesSalesOrder.ChangeDate = DateTime.ParseExact(erpSalesOrder.FChangeDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesOrder.CancelStatus = erpSalesOrder.FCancelStatus; MesSalesOrder.CancellerId = erpSalesOrder.FCancellerId; MesSalesOrder.VersionNo = Convert.ToDecimal(erpSalesOrder.FVersionNo); MesSalesOrder.ChangerId = erpSalesOrder.FChangerId; MesSalesOrder.EntryNote = erpSalesOrder.FEntryNote; return MesSalesOrder; } // 将 ErpSalesOrderDetail 对象转换为 SalesOrderDetail 对象的方法 public List GetErpSalesOrderDetail( List erpSalesOrderDetails, string type) { return erpSalesOrderDetails.Select(s => { var entity = new SalesOrderDetail { Id = Convert.ToDecimal(s.Id), ErpId = Convert.ToDecimal(s.ErpID), EHid = Convert.ToDecimal(s.EHID), MaterialIDd = s.FMaterialId, UnitId = s.FUnitID, Qty = Convert.ToDecimal(s.FQty), PriceUnitId = s.FPriceUnitId, PriceUnitQty = Convert.ToDecimal(s.FPriceUnitQty), DeliveryDate = s.FDeliveryDate != null ? DateTime.ParseExact(s.FDeliveryDate, "yyyy-MM-dd HH:mm:ss", null) : null, IsFree = s.FIsFree, OwnerTypeId = s.FOwnerTypeId, OwnerId = s.FOwnerId, EntryNote = s.FEntryNote, MtoNo = s.FMtoNo, Lot = s.FLot, DeliveryMaxQty = Convert.ToDecimal(s.FDeliveryMaxQty), DeliveryMinQty = Convert.ToDecimal(s.FDeliveryMinQty), OutLmtUnitId = s.FOutLmtUnitID, MrpCloseStatus = s.FMrpCloseStatus, MrpTerminateStatus = s.FMrpTerminateStatus, TerminateDate = s.FTerminateDate != null ? DateTime.ParseExact(s.FTerminateDate, "yyyy-MM-dd HH:mm:ss", null) : null, TerminaterId = s.FTerminaterId, SrcType = s.FSrcType, SrcBillNo = s.FSrcBillNo, DeliQty = Convert.ToDecimal(s.FDeliQty), StockOutQty = Convert.ToDecimal(s.FStockOutQty), BaseRetNoticeQty = Convert.ToDecimal(s.FBaseRetNoticeQty), BaseReturnQty = Convert.ToDecimal(s.FBaseReturnQty), BaseRemainOutQty = Convert.ToDecimal(s.FBaseRemainOutQty), BaseArQty = Convert.ToDecimal(s.FBASEARQTY), }; var single = salesOrderDetailManager.GetSingle(it => it.Id == entity.Id); if (single != null) entity.Id = single.Id; return entity; }).ToList(); } }