using MES.Service.DB; using MES.Service.Dto.service; using MES.Service.Modes; using SqlSugar; namespace MES.Service.service.Warehouse; public class MesInvItemOutCDetailsManager : Repository { //当前类已经继承了 Repository 增、删、查、改的方法 //这里面写的代码不会给覆盖,如果要重新生成请删除 MesInvItemOutCDetailsManager.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(MesInvItemOutCDetails).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 MesInvItemOutCDetails(); //测试参数 var insertArray = new[] { insertData }; base.Insert(insertData); //插入 base.InsertRange(insertArray); //批量插入 var id = base.InsertReturnIdentity(insertData); //插入返回自增列 AsInsertable(insertData).ExecuteCommand(); //我们可以转成 Insertable实现复杂插入 /*********更新*********/ var updateData = new MesInvItemOutCDetails(); //测试参数 var updateArray = new[] { updateData }; //测试参数 base.Update(updateData); //根据实体更新 base.UpdateRange(updateArray); //批量更新 //base.Update(it => new MesInvItemOutCDetails() { ClassName = "a", CreateTime = DateTime.Now }, it => it.id==1);// 只更新ClassName列和CreateTime列,其它列不更新,条件id=1 AsUpdateable(updateData).ExecuteCommand(); //转成Updateable可以实现复杂的插入 /*********删除*********/ var deldata = new MesInvItemOutCDetails(); //测试参数 base.Delete(deldata); //根据实体删除 base.DeleteById(1); //根据主键删除 base.DeleteById(new[] { 1, 2 }); //根据主键数组删除 base.Delete(it => 1 == 2); //根据条件删除 AsDeleteable().Where(it => 1 == 2) .ExecuteCommand(); //转成Deleteable实现复杂的操作 } #endregion public MesInvItemOutCDetails GetOutList(WarehouseQuery query) { var mesInvItemBarcodes = Db.Queryable() .Where(s => s.ItemBarcode == query.barcode).Count(); if (mesInvItemBarcodes <= 0) { throw new Exception("条码不存在"); } var mesInvItemOutCDetails = Db.Queryable() .Where(s => s.ItemBarcode == query.barcode && s.Receive == 0).Count(); if (mesInvItemOutCDetails <= 0) { throw new Exception("条码不符合接收条件,请检查!"); } var entity = Db.Queryable((a, b, c) => new JoinQueryInfos(JoinType.Left, a.ItemOutId == b.Id, JoinType.Left, a.ItemNo == c.ItemNo)) .Where((a, b, c) => a.ItemBarcode == query.barcode) .Select((a, b, c) => new MesInvItemOutCDetails { PbillNo = b.ItemOutNo, WorkNo = a.WorkNo, ItemNo = a.ItemNo, ItemName = c.ItemName, Quantity = a.Quantity }).First(); if (entity == null) { throw new Exception("出库条码" + query.barcode + " 不存在,请确认!"); } return entity; } public MaterialReceipt GetFormList(WarehouseQuery query) { var mesInvItemBarcodes = Db.Queryable() .Where(s => s.ItemBarcode == query.barcode).Count(); if (mesInvItemBarcodes <= 0) { throw new Exception("条码不存在"); } var mesInvItemOutCDetails = Db.Queryable() .Where(s => s.ItemBarcode == query.barcode).First(); MaterialReceipt entity = new MaterialReceipt { InvItemoutCDetails = GetMesInvItemOutCDetails(mesInvItemOutCDetails.PbillNo), ItemOuts = GetMesInvItemOuts(mesInvItemOutCDetails.PbillNo) }; return entity; } public MesInvItemOutCDetails confirmReceipt(WarehouseQuery query) { if (string.IsNullOrWhiteSpace(query.barcode)) { throw new Exception("请扫出库条码!"); } if (string.IsNullOrWhiteSpace(query.billNo)) { throw new Exception("出库单据不能为空!"); } var barcodeInfo = GetBarcodeInfo(query.barcode); if (barcodeInfo.Receive == 1) { throw new Exception("此条码已经接收,请检查!"); } UseTransaction(db => { var count = db.Updateable() .SetColumns(s => s.Receive == 1) .Where(s => s.ItemBarcode == barcodeInfo.ItemBarcode).ExecuteCommand(); return 1; }); return barcodeInfo; } public List GetMesInvItemOutCDetails(string billno) { return Db.Queryable() .Where(s => s.PbillNo == billno).ToList(); } public MesInvItemOuts GetMesInvItemOuts(string billno) { return Db.Queryable() .Where(a => a.ItemOutNo == billno).Single(); } private MesInvItemOutCDetails GetBarcodeInfo(string itemBarcode) { // Get barcode information return Db.Queryable() .First(b => b.ItemBarcode == itemBarcode); } }