0

有时我们需要在事务中保存一些临时数据。如果没有完成,它将被删除。例如,上传图片。

最好的策略是什么?将数据保存在实际数据库中并执行将删除不完整数据(行)或将其保存在临时空间中的任务调度或什么?

非常感谢 。

4

1 回答 1

1

临时数据示例,我希望我做对了。以 busroute 为例:-

  if (id != busRoute.BusRouteCode)
        {
            return NotFound();
        }

        if (ModelState.IsValid)
        {
            try
            {
                _context.Update(busRoute);
                await _context.SaveChangesAsync();
            }
            catch (DbUpdateConcurrencyException)
            {
                if (!BusRouteExists(busRoute.BusRouteCode))
                {
                    return NotFound();
                }
                else
                {
                    throw;
                }
            }
            return RedirectToAction(nameof(Index));
        }
        return View(busRoute);
    }

    public async Task<IActionResult> Create([Bind("BusRouteCode,RouteName")] BusRoute busRoute)
    {
        if (ModelState.IsValid)
        {
            _context.Add(busRoute);
            await _context.SaveChangesAsync();
            return RedirectToAction(nameof(Index));
        }
        return View(busRoute);
    }

对于索引:- TempData["message"] = "Welcome to the Membership List...";

        if (MemberId == null)
        {
            TempData["message"] = "Please select a Member...";
            RedirectToAction("SHMember", "Index");
        }

        string memberId = MemberId.ToString();
        var FullName = _context.Membership
            .Include("FullName")
            .Where(m => m.MemberId == MemberId)
            .Select(m => m.Member.FullName)
            .FirstOrDefault(); 

        if (memberId != null)
        {
            HttpContext.Session.SetString("MemberId", memberId);
            HttpContext.Session.SetString("FullName", FullName);
        }
        else
        {
            memberId = HttpContext.Session.GetString("MemberId");
            FullName = HttpContext.Session.GetString("FullName");

            if (memberId == null)
            {
                //return to View and Display Message
                TempData["message"] = "Please select a Member...";
                return RedirectToAction("Index", "Member");
            }
        }

        ViewBag.FullName = HttpContext.Session.GetString("FullName");

        var MembershipContext = _context.Membership
            .Where(m => m.MemberId == MemberId)
            .OrderByDescending(m=>m.Year);



        return View(await MembershipContext.ToListAsync());
于 2018-10-30T12:55:33.967 回答