zoukankan      html  css  js  c++  java
  • EF中更新数据

    原来EF中不查询数据库也可以直接更新!

    EF中会为每个 管理的 实体对象 创建一个代理包装类对象,其中会跟踪 实体对象 的状态和每个属性的状态;

    一、通常使用EF更新的方式,先查询出要修改的数据,然后再修改新的值;实体对象被修改的属性 在 代理包装类对象里 的对应属性状态会被修改记录下修改状态,等到调用SaveChanges时,EF会遍历其管理的每个实体对象,并根据其 包装类对象 的状态,生成增删改查sql语句并执行;       此例中修改操作,会生成 修改的sql语句(注意:此处只为修改过的属性生成sql语句),最后执行。       缺点:修改先还要查询,难受~~~~

    复制代码
     1 //1.先查询要修改的原数据
     2 Models.BlogArticle modelNew = db.BlogArticles.Where(a => a.AId == model.AId).FirstOrDefault();
     3 
     4 //2.设置修改后的值
     5 modelNew.ATitle = "新的数据";
     6 modelNew.AContent = "新的数据~~~~~~";
     7 modelNew.ACate = 12;
     8 
     9 //3.跟新到数据库
    10 db.SaveChanges();
    复制代码

    二、为避免先查询数据库,可以直接将 被修改的实体对象 添加到 EF中管理(此时为附加状态Attached),并手动设置其为未修改状态(Unchanged),同时设置被修改的实体对象 的 包装类对象 对应属性为修改状态。      优点:修改前不需要查询数据库。

    复制代码
     1 //0.0创建修改的 实体对象
     2 Models.BlogArticle model = new BlogArticle();
     3 model.AId = 12;
     4 model.ATitle = "新的数据";
     5 model.AContent = "新的数据~~~~~";
     6 
     7 //0.1添加到EF管理容器中,并获取 实体对象 的伪包装类对象
     8 DbEntityEntry<Models.BlogArticle> entry = db.Entry<Models.BlogArticle>(model);
     9 
    10 //**如果使用 Entry 附加 实体对象到数据容器中,则需要手动 设置 实体包装类的对象 的 状态为 Unchanged**
    11 //**如果使用 Attach 就不需要这句
    12 entry.State = System.Data.EntityState.Unchanged;
    13 
    14 //0.2标识 实体对象 某些属性 已经被修改了
    15 entry.Property("ATitle").IsModified = true;
    16 entry.Property("AContent").IsModified = true;
    17 
    18 //3.跟新到数据库
    19 db.SaveChanges();
    复制代码
  • 相关阅读:
    操纵持久化对象
    面阵和线扫工业相机选型
    线扫描镜头简介及选型
    Halcon的anisotropic_diffusion()函数,用于对图像进行各向异性散射增强处理
    VB、C#等高级语言与三菱PLC(Q系列、L系列、FX系列、A系列)串口、以太网通讯的DLL及源代码
    Halcon学习笔记之支持向量机
    C#中使用byte[]数据,生成Bitmap(256色 灰度 BMP位图)源代码
    Halcon学习SVM
    利用MLP(多层感知器)创建一个新的OCR分级器
    Halcon中OCR的实现及关键函数解析
  • 原文地址:https://www.cnblogs.com/mhker/p/2962204.html
Copyright © 2011-2022 走看看