using MES.Service.DB; using MES.Service.Dto.webApi; using MES.Service.Modes; using SqlSugar; namespace MES.Service.service.BasicData; public class SalesDeliveryNoticeManager : Repository { //当前类已经继承了 Repository 增、删、查、改的方法 //这里面写的代码不会给覆盖,如果要重新生成请删除 SalesReturnNoticeManager.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(SalesReturnNotice).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 SalesDeliveryNotice(); //测试参数 var insertArray = new[] { insertData }; base.Insert(insertData); //插入 base.InsertRange(insertArray); //批量插入 var id = base.InsertReturnIdentity(insertData); //插入返回自增列 AsInsertable(insertData).ExecuteCommand(); //我们可以转成 Insertable实现复杂插入 /*********更新*********/ var updateData = new SalesDeliveryNotice(); //测试参数 var updateArray = new[] { updateData }; //测试参数 base.Update(updateData); //根据实体更新 base.UpdateRange(updateArray); //批量更新 //base.Update(it => new SalesReturnNotice() { ClassName = "a", CreateTime = DateTime.Now }, it => it.id==1);// 只更新ClassName列和CreateTime列,其它列不更新,条件id=1 AsUpdateable(updateData).ExecuteCommand(); //转成Updateable可以实现复杂的插入 /*********删除*********/ var deldata = new SalesDeliveryNotice(); //测试参数 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 SalesDeliveryNoticeDetailManager salesDeliveryNoticeDetailManager = new(); // Save 方法用于保存单个 销售订单(SalesOrder) 记录,根据类型执行不同的操作 public bool Save(SaleDeliveryNotice saleDeliveryNotice) { var salesDeliveryNoticeErpSalesDeliveryNotice = saleDeliveryNotice.ErpSalesDeliveryNotice; var mesSalesDeliveryNotice = GetSalesDeliveryNotice(salesDeliveryNoticeErpSalesDeliveryNotice); var mesSalesDeliveryNoticeDetails = GetErpSalesDeliveryNoticeDetail(saleDeliveryNotice.ErpSalesDeliveryNoticeDetails, salesDeliveryNoticeErpSalesDeliveryNotice.type); return UseTransaction(db => { switch (salesDeliveryNoticeErpSalesDeliveryNotice.type) { case "3": return UpdateData(db, mesSalesDeliveryNotice, mesSalesDeliveryNoticeDetails) ? 1 : 0; case "2": case "4": case "5": case "6": return SaveOrUpdateData(db, mesSalesDeliveryNotice, mesSalesDeliveryNoticeDetails) ? 1 : 0; default: throw new NotImplementedException( $"type没有{salesDeliveryNoticeErpSalesDeliveryNotice.type}这个类型"); } }) > 0; } // 更新数据的方法(单纯的删除) private bool UpdateData(SqlSugarScope db, SalesDeliveryNotice salesDeliveryNotice, List salesDeliveryNoticeDetails) { var decimals = salesDeliveryNoticeDetails.Select(s => s.Id).ToArray(); var update = base.DeleteById(salesDeliveryNotice.Id); var insertOrUpdate = db .Deleteable().In(decimals) .ExecuteCommand() > 0; if (update && insertOrUpdate) return true; throw new NotImplementedException("删除失败"); } // 插入或更新数据的方法 private bool SaveOrUpdateData(SqlSugarScope db, SalesDeliveryNotice salesDeliveryNotice, List salesDeliveryNoticeDetails) { if (salesDeliveryNotice.Id != null) base.DeleteById(salesDeliveryNotice.Id); if (salesDeliveryNoticeDetails.Count > 0) db.Deleteable() .Where(s => s.ErpId == salesDeliveryNotice.Id).ExecuteCommand(); var orUpdate = base.Insert(salesDeliveryNotice); var baOrUpdate = salesDeliveryNoticeDetailManager.InsertRange(salesDeliveryNoticeDetails); if (orUpdate && baOrUpdate) return true; throw new NotImplementedException("插入或更新失败"); } // 批量保存记录的方法 public bool SaveList(List saleDeliveryNotices) { var result = saleDeliveryNotices.Select(Save).ToList(); return result.All(b => b); } // 将 erpSalesDeliveryNotice 对象转换为 SalesReturnNotice 对象的方法 public SalesDeliveryNotice GetSalesDeliveryNotice(ErpSalesDeliveryNotice erpSalesDeliveryNotice) { var eid = Convert.ToDecimal(erpSalesDeliveryNotice.Id); var MesSalesDeliveryNotice = new SalesDeliveryNotice(); var single = base.GetSingle(it => it.Id == eid); if (single != null) MesSalesDeliveryNotice.Id = single.Id; MesSalesDeliveryNotice.ErpId = erpSalesDeliveryNotice.erpID; MesSalesDeliveryNotice.BillType = erpSalesDeliveryNotice.fBillTypeID; MesSalesDeliveryNotice.BillNo = erpSalesDeliveryNotice.fBillNo; if (erpSalesDeliveryNotice.fDate != null) MesSalesDeliveryNotice.FDate = DateTime.ParseExact(erpSalesDeliveryNotice.fDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesDeliveryNotice.Currency = erpSalesDeliveryNotice.fSettleCurrld; MesSalesDeliveryNotice.SalesDept = erpSalesDeliveryNotice.fSaleDeptId; MesSalesDeliveryNotice.Customer = erpSalesDeliveryNotice.fCustomerID; MesSalesDeliveryNotice.DeliveryMethod = erpSalesDeliveryNotice.fHeadDeliveryWay; MesSalesDeliveryNotice.DeliveryLocation = erpSalesDeliveryNotice.fHeadLocId; MesSalesDeliveryNotice.Carrier = erpSalesDeliveryNotice.fCarrierID; MesSalesDeliveryNotice.SettleParty = erpSalesDeliveryNotice.fCarriageNO; MesSalesDeliveryNotice.SettleParty = erpSalesDeliveryNotice.fDeliveryDeptID; MesSalesDeliveryNotice.InventoryGroup = erpSalesDeliveryNotice.fStockerGroupId; MesSalesDeliveryNotice.WarehouseManager = erpSalesDeliveryNotice.fStockerId; MesSalesDeliveryNotice.SalesGroup = erpSalesDeliveryNotice.fSaleGroupId; MesSalesDeliveryNotice.SalesPerson = erpSalesDeliveryNotice.fSalesManId; MesSalesDeliveryNotice.Receiver = erpSalesDeliveryNotice.fReceiveCusId; MesSalesDeliveryNotice.ReceiverContact = erpSalesDeliveryNotice.fReceiveCusContact; MesSalesDeliveryNotice.ReceiverAddress = erpSalesDeliveryNotice.fReceiveAddress; MesSalesDeliveryNotice.ReceiverName = erpSalesDeliveryNotice.fLinkMan; MesSalesDeliveryNotice.ReceiverName = erpSalesDeliveryNotice.fLinkPhone; MesSalesDeliveryNotice.SettleParty = erpSalesDeliveryNotice.fSettleID; MesSalesDeliveryNotice.PayerParty = erpSalesDeliveryNotice.fPayerID; MesSalesDeliveryNotice.CreatedBy = erpSalesDeliveryNotice.fCreatorId; if (erpSalesDeliveryNotice.fCreateDate != null) MesSalesDeliveryNotice.CreatedDate = DateTime.ParseExact(erpSalesDeliveryNotice.fCreateDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesDeliveryNotice.ModifiedBy = erpSalesDeliveryNotice.fModifierId; if (erpSalesDeliveryNotice.fModifyDate != null) MesSalesDeliveryNotice.ModifiedDate = DateTime.ParseExact(erpSalesDeliveryNotice.fModifyDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesDeliveryNotice.ApprovedBy = erpSalesDeliveryNotice.fApproverId; if (erpSalesDeliveryNotice.fApproveDate != null) MesSalesDeliveryNotice.ApprovedDate = DateTime.ParseExact(erpSalesDeliveryNotice.fApproveDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesDeliveryNotice.ClosedBy = erpSalesDeliveryNotice.fCloserId; MesSalesDeliveryNotice.CloseReason = erpSalesDeliveryNotice.fCloseReason; MesSalesDeliveryNotice.CloseStatus = erpSalesDeliveryNotice.fBillCloseStatus; MesSalesDeliveryNotice.CancelStatus = erpSalesDeliveryNotice.fCancelStatus; MesSalesDeliveryNotice.CancelledBy = erpSalesDeliveryNotice.fCancellerId; if (erpSalesDeliveryNotice.fCancelDate != null) MesSalesDeliveryNotice.CancelDate = DateTime.ParseExact(erpSalesDeliveryNotice.fCancelDate, "yyyy-MM-dd HH:mm:ss", null); MesSalesDeliveryNotice.BillStatus = erpSalesDeliveryNotice.fDocumentStatus; return MesSalesDeliveryNotice; } // 将 erpSalesDeliveryNoticeDetail 对象转换为 SalesReturnNoticeDetail 对象的方法 public List GetErpSalesDeliveryNoticeDetail( List erpSalesDeliveryNoticeDetails, string type) { return erpSalesDeliveryNoticeDetails.Select(s => { var entity = new SalesDeliveryNoticeDetail { Id = Convert.ToDecimal(s.Id), ErpLineId = s.erpID, ErpHeadId = s.ehid, MaterialId = s.fMaterialId, MaterialName = s.fUnitID, SalesQuantity = Convert.ToDecimal(s.fQty), IsFree = s.fIsFree, DeliveryDate = s.fDeliverydate != null ? DateTime.ParseExact(s.fDeliverydate, "yyyy-MM-dd HH:mm:ss", null) : null, WareHouse = s.fStockId, PlanTrackingNumber = s.fMtoNo, LotNumber = s.fLot, PriceQty = Convert.ToDecimal(s.fPriceUnitQty), OwnerId = s.fOwnerIdHead, InventoryUnit = s.fStockUnitID, InventoryQuantity = Convert.ToDecimal(s.fStockQty), PlanDeliveryDate = s.fPlanDeliveryDate != null ? DateTime.ParseExact(s.fPlanDeliveryDate, "yyyy-MM-dd HH:mm:ss", null) : null, OutLmtUnit = s.fOutLmtUnit, OutMaxQty = Convert.ToDecimal(s.fOutMaxQty), OutMinQty = Convert.ToDecimal(s.fOutMinQty), DeliveryLoc = s.fDeliveryLoc, DeliveryAddress = s.fDeliveryLAddress, SourceBillNo = s.fSrcBillNo, OrderBillNo = s.fOrderNo, TerminationStatus = s.fTerminationStatus, TerminationDate = s.fTerminateDate != null ? DateTime.ParseExact(s.fTerminateDate, "yyyy-MM-dd HH:mm:ss", null) : null, SumOutQty = Convert.ToDecimal(s.fSumOutQty), RemainOutQty = Convert.ToDecimal(s.fRemainOutQty), FentryNote = s.FNoteEntry, }; var single = salesDeliveryNoticeDetailManager.GetSingle(it => it.Id == entity.Id); if (single != null) entity.Id = single.Id; return entity; }).ToList(); } }