5.6.4 《DbSet与DbContext》

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

5.6.5 《数据更新的奥秘》 

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

5.6.4 《DbSet与DbContext》

EF – 5.DbSet与DbContext,数据更新奥秘-LMLPHP

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

EF – 5.DbSet与DbContext,数据更新奥秘-LMLPHP

5.6.5 《数据更新的奥秘》

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

EF – 5.DbSet与DbContext,数据更新奥秘-LMLPHP

(2)CurrentValue

EF – 5.DbSet与DbContext,数据更新奥秘-LMLPHP

{  
………
//状态
[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("\n修改属性前的状态:{0}", entry.State); //Unchanged Helper.PrintEntityPropertyValye(entry);
users.UserDescription = "10008";
context.ChangeTracker.DetectChanges();//更新实体对象当前的状态 //Modified
Console.WriteLine("\n修改属性后的状态:{0}", entry.State); Helper.PrintEntityPropertyValye(entry); //result 为当前状态
int result = context.SaveChanges();
Console.WriteLine("\n保存属性后的状态:{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}\n原始值:{1}\n数据库值:{2}\n", current, original, database);
}
}

EF – 5.DbSet与DbContext,数据更新奥秘-LMLPHP

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

只是查询(只读)的话。

EF – 5.DbSet与DbContext,数据更新奥秘-LMLPHP

05-11 16:14