zoukankan      html  css  js  c++  java
  • EF – 5.DbSet与DbContext,数据更新奥秘

    5.6.4 《DbSet与DbContext》

    介绍DbSet与DbContext中的核心属性及重要方法。

    5.6.5 《数据更新的奥秘》 

    这一讲极为重要,因为它揭示出了Entity Framework实现数据更新的内部机理,了解这些内容,对于用好Entity Framework非常重要。

    5.6.4 《DbSet与DbContext》

    image

    介绍DbSet与DbContext中的核心属性及重要方法。

    Image 1

    5.6.5 《数据更新的奥秘》

    这一讲极为重要,因为它揭示出了Entity Framework实现数据更新的内部机理,了解这些内容,对于用好Entity Framework非常重要。

    Image 2

    (2)CurrentValue

    image

    {  
    ………
    //状态 [TestMethod] public void TestShowUPMS_UserState() { var users = (from c in context.UPMS_User orderby c.UserId descending select c).FirstOrDefault(); if (users != null) { DbEntityEntry<UPMS_User> entry = context.Entry<UPMS_User>(users); Console.WriteLine(" 修改属性前的状态:{0}", entry.State); //Unchanged Helper.PrintEntityPropertyValye(entry); users.UserDescription = "10008"; context.ChangeTracker.DetectChanges();//更新实体对象当前的状态 //Modified Console.WriteLine(" 修改属性后的状态:{0}", entry.State); Helper.PrintEntityPropertyValye(entry); //result 为当前状态 int result = context.SaveChanges(); Console.WriteLine(" 保存属性后的状态:{0}", entry.State); //Unchanged Helper.PrintEntityPropertyValye(entry); } } } public class Helper { public static void PrintEntityPropertyValye(DbEntityEntry<UPMS_User> entry) { string current = entry.CurrentValues["UserDescription"].ToString(); string original = entry.OriginalValues["UserDescription"].ToString(); string database = entry.GetDatabaseValues()["UserDescription"].ToString(); Console.WriteLine("当前值:{0} 原始值:{1} 数据库值:{2} ", current, original, database); } }

    Image 4

    (3)禁用跟踪状态(提升性能)

    只是查询(只读)的话。

    image

  • 相关阅读:
    使用阿里的EasyExcel实现表格导出功能
    推荐一款实用的java工具包---Hutool
    MySQL(二)锁机制【表级锁、页面锁、行级锁】
    MySQL(一)存储引擎
    使用redis的increment()方法实现计数器功能
    Redis缓存浅析
    Dubbo服务介绍
    SpringMVC工作执行流程详解
    GC垃圾回收机制----GC回收算法(GC机制必会知识点)
    数据结构之常见的数据结构
  • 原文地址:https://www.cnblogs.com/tangge/p/4528102.html
Copyright © 2011-2022 走看看