DbContext正在处理

本文关键字:处理 DbContext | 更新日期: 2023-09-27 18:03:48

DbContext

public class HaberPortalDB : DbContext
{
    public DbSet<Haberler> Haberler { get; set; }
    public DbSet<Kategoriler> Kategoriler { get; set; }
    public DbSet<Yazarlar> Yazarlar { get; set; }
}
public class Haberler
{
    public virtual int Id { get; set; }
    public virtual string Baslik { get; set; }
    public virtual string Aciklama { get; set; }
    public virtual string Icerik { get; set; }
    public virtual int YazarId { get; set; }
    public virtual Yazarlar Yazar { get; set; }
    public virtual int KategoriId { get; set; }
    public virtual Kategoriler Kategori { get; set; }
    public virtual ICollection<Resimler> Resimler { get; set; }
}
public class Kategoriler
{
    public virtual int Id { get; set; }
    public virtual string KategoriAdi { get; set; }
    public virtual string Aciklama { get; set; }
    public virtual ICollection<Haberler> Haberler { get; set; }
}
public class Yazarlar
{
    public virtual int Id { get; set; }
    public virtual string YazarAdi { get; set; }
    public virtual string Ozgecmis { get; set; }
    public virtual string Eposta { get; set; }
    public virtual ICollection<Haberler> Haberler { get; set; }
}
public class Resimler
{
    public virtual int Id { get; set; }
    public virtual string Url { get; set; }
    public virtual string Ad { get; set; }
    public virtual Haberler Haber { get; set; }
}

脚手架正在生成以下动作方法

    //
    // GET: /Test/
    public ActionResult Index()
    {
        return View(db.Kategoriler.ToList());
    }
    //
    // GET: /Test/Details/5
    public ActionResult Details(int id = 0)
    {
        Kategoriler kategoriler = db.Kategoriler.Find(id);
        if (kategoriler == null)
        {
            return HttpNotFound();
        }
        return View(kategoriler);
    }
    //
    // GET: /Test/Create
    public ActionResult Create()
    {
        return View();
    }
    //
    // POST: /Test/Create
    [HttpPost]
    public ActionResult Create(Kategoriler kategoriler)
    {
        if (ModelState.IsValid)
        {
            db.Kategoriler.Add(kategoriler);
            db.SaveChanges();
            return RedirectToAction("Index");
        }
        return View(kategoriler);
    }
    //
    // GET: /Test/Edit/5
    public ActionResult Edit(int id = 0)
    {
        Kategoriler kategoriler = db.Kategoriler.Find(id);
        if (kategoriler == null)
        {
            return HttpNotFound();
        }
        return View(kategoriler);
    }
    //
    // POST: /Test/Edit/5
    [HttpPost]
    public ActionResult Edit(Kategoriler kategoriler)
    {
        if (ModelState.IsValid)
        {
            db.Entry(kategoriler).State = EntityState.Modified;
            db.SaveChanges();
            return RedirectToAction("Index");
        }
        return View(kategoriler);
    }
    //
    // GET: /Test/Delete/5
    public ActionResult Delete(int id = 0)
    {
        Kategoriler kategoriler = db.Kategoriler.Find(id);
        if (kategoriler == null)
        {
            return HttpNotFound();
        }
        return View(kategoriler);
    }
    //
    // POST: /Test/Delete/5
    [HttpPost, ActionName("Delete")]
    public ActionResult DeleteConfirmed(int id)
    {
        Kategoriler kategoriler = db.Kategoriler.Find(id);
        db.Kategoriler.Remove(kategoriler);
        db.SaveChanges();
        return RedirectToAction("Index");
    }
    protected override void Dispose(bool disposing)
    {
        db.Dispose();
        base.Dispose(disposing);
    }

每种方法都有断点。Dispose()方法是在其他方法工作之后工作的。

如何为每个工作方法激发Dispose()方法?

DbContext正在处理

需要注意的几点:

  • 控制器的使用寿命仅与每个请求一样长
  • 每个请求将执行一个操作方法
  • 当控制器完成请求时调用Dispose

因此,这就是每次请求过程中发生的情况:

  1. 控制器已初始化
  2. DbContext已初始化
  3. 执行操作方法
  4. 控制器Dispose方法执行