Exemple #1
0
 public void FinishCheck(DbContext db, SystemStatus systemStatus, StocktakingLogHd hd, List <ProfitAndLossLog> plLogList, List <InventoryLossLog> lossLogList, List <UnlistedGoodsLog> ugLogList, List <InventoryLog> stockLogList)
 {
     using (TransactionScope ts = new TransactionScope())
     {
         // 让使用typeof(T).Name标签的所有缓存过期
         QueryCacheManager.ExpireTag(nameof(SystemStatus));
         QueryCacheManager.ExpireTag(nameof(StocktakingLogHd));
         QueryCacheManager.ExpireTag(nameof(ProfitAndLoss));
         QueryCacheManager.ExpireTag(nameof(VProfitAndLossLog));
         QueryCacheManager.ExpireTag(nameof(InventoryLoss));
         QueryCacheManager.ExpireTag(nameof(VInventoryLossLog));
         QueryCacheManager.ExpireTag(nameof(UnlistedGoods));
         QueryCacheManager.ExpireTag(nameof(VUnlistedGoodsLog));
         QueryCacheManager.ExpireTag(nameof(Inventory));
         QueryCacheManager.ExpireTag(nameof(VInventoryLog));
         db.Configuration.ValidateOnSaveEnabled = false;
         BaseDAL baseDAL = DALFty.Create <BaseDAL>();
         // 更新状态表
         db.Entry(systemStatus).State = EntityState.Modified;
         db.SaveChanges();
         // 添加盘点日志
         db.Set <StocktakingLogHd>().Add(hd);
         db.SaveChanges();
         // 保存盘点差异日志表
         if (plLogList.Count > 0)
         {
             baseDAL.AddByBulkCopy <ProfitAndLossLog>(db, plLogList);
         }
         // 保存损耗确认单日志表
         if (lossLogList.Count > 0)
         {
             baseDAL.AddByBulkCopy <InventoryLossLog>(db, lossLogList);
         }
         // 保存未上架商品确认单日志表
         if (ugLogList.Count > 0)
         {
             baseDAL.AddByBulkCopy <UnlistedGoodsLog>(db, ugLogList);
         }
         // 保存账面库存日志表
         if (stockLogList.Count > 0)
         {
             baseDAL.AddByBulkCopy <InventoryLog>(db, stockLogList);
         }
         // 删除盘点差异表
         db.Set <ProfitAndLoss>().DeleteFromQuery();
         // 删除损耗确认单
         db.Set <InventoryLoss>().DeleteFromQuery();
         // 删除未上架商品确认单
         db.Set <UnlistedGoods>().DeleteFromQuery();
         // 删除账面库存表
         db.Set <Inventory>().DeleteFromQuery();
         db.Configuration.ValidateOnSaveEnabled = true;
         ts.Complete();
     }
 }
Exemple #2
0
 public void SaveProfitAndLoss(DbContext db, SystemStatus systemStatus, StocktakingLogHd hd, List <StocktakingLogDtl> dtlList, List <ProfitAndLoss> insertList, List <ProfitAndLoss> updateList)
 {
     using (TransactionScope ts = new TransactionScope())
     {
         // 让使用typeof(T).Name标签的所有缓存过期
         QueryCacheManager.ExpireTag(nameof(StocktakingLogHd));
         QueryCacheManager.ExpireTag(nameof(StocktakingLogDtl));
         QueryCacheManager.ExpireTag(nameof(ProfitAndLoss));
         QueryCacheManager.ExpireTag(nameof(Stocktaking));
         db.Configuration.ValidateOnSaveEnabled = false;
         BaseDAL baseDAL = DALFty.Create <BaseDAL>();
         // 更新状态表
         db.Entry(systemStatus).State = EntityState.Modified;
         db.SaveChanges();
         // 添加盘点日志
         db.Set <StocktakingLogHd>().Add(hd);
         db.SaveChanges();
         if (dtlList.Count > 0)
         {
             baseDAL.AddByBulkCopy <StocktakingLogDtl>(db, dtlList);
         }
         // 保存盘点差异表
         if (insertList.Count > 0)
         {
             baseDAL.AddByBulkCopy <ProfitAndLoss>(db, insertList);
         }
         if (updateList.Count > 0)
         {
             db.Set <ProfitAndLoss>().BulkUpdate(updateList);
         }
         // 删除盘点导入表
         db.Set <Stocktaking>().DeleteFromQuery();
         db.SaveChanges();
         db.Configuration.ValidateOnSaveEnabled = true;
         ts.Complete();
     }
 }
Exemple #3
0
 public void Insert(WmsContext db, UsersInfo obj, List <Permission> pList, List <ButtonPermission> btnList)
 {
     using (TransactionScope ts = new TransactionScope())
     {
         // 让使用typeof(T).Name标签的所有缓存过期
         QueryCacheManager.ExpireTag(nameof(UsersInfo));
         QueryCacheManager.ExpireTag(nameof(Permission));
         QueryCacheManager.ExpireTag(nameof(ButtonPermission));
         db.Configuration.ValidateOnSaveEnabled = false;
         BaseDAL baseDAL = DALFty.Create <BaseDAL>();
         db.Set <UsersInfo>().Add(obj);
         db.SaveChanges();
         if (pList.Count > 0)
         {
             baseDAL.AddByBulkCopy <Permission>(db, pList);
         }
         if (btnList.Count > 0)
         {
             baseDAL.AddByBulkCopy <ButtonPermission>(db, btnList);
         }
         db.Configuration.ValidateOnSaveEnabled = true;
         ts.Complete();
     }
 }