5.6.4 《DbSet与DbContext》 数据库
介绍DbSet与DbContext中的核心属性及重要方法。性能
5.6.5 《数据更新的奥秘》 spa
这一讲极为重要,由于它揭示出了Entity Framework实现数据更新的内部机理,了解这些内容,对于用好Entity Framework很是重要。3d
5.6.4 《DbSet与DbContext》 code
介绍DbSet与DbContext中的核心属性及重要方法。对象
5.6.5 《数据更新的奥秘》blog
这一讲极为重要,由于它揭示出了Entity Framework实现数据更新的内部机理,了解这些内容,对于用好Entity Framework很是重要。ip
(2)CurrentValuestring
{
………
//状态 [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); } }
(3)禁用跟踪状态(提高性能)it
只是查询(只读)的话。