改写第一天的增删改查方法,观察增删改查的本质

 using System;
using System.Collections.Generic;
using System.Data.Entity.Infrastructure;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFConsole
{
class Program
{
public static remotingEntities dbContext = new remotingEntities();
static void Main(string[] args)
{
//addOtherMethod(); //updateOtherMethod();
//removeOtherMethod();
Console.ReadKey();
}
/// <summary>
/// 另一种添加方法
/// </summary>
public static void addOtherMethod()
{
int res = -;
user tempData = new user() { id="",name="EntityEntry"};
DbEntityEntry<user> entry = dbContext.Entry<user>(tempData);
entry.State = System.Data.EntityState.Added;
res=dbContext.SaveChanges();
Console.WriteLine(res>?"添加成功"+tempData.name:"添加失败");
}
/// <summary>
/// 另一种修改方法
/// </summary>
public static void updateOtherMethod()
{
int res = -;
user tempData = new user() { id = "", name = "update EntityEntry" };
DbEntityEntry<user> entry = dbContext.Entry<user>(tempData);
entry.State = System.Data.EntityState.Unchanged;
entry.Property("name").IsModified = true;
res=dbContext.SaveChanges();
Console.WriteLine(res>?"修改成功":"修改失败");
}
/// <summary>
/// 另一种删除方法
/// </summary>
public static void removeOtherMethod()
{
int res = -;
user tempData = new user() { id = "" };
DbEntityEntry<user> entry = dbContext.Entry<user>(tempData);
entry.State = System.Data.EntityState.Deleted;
res=dbContext.SaveChanges();
Console.WriteLine(res>?"删除成功":"删除失败");
}
}
}

依次执行添加,修改,删除,我们会看到结果。

官方推荐当修改实体数据的时候是先从数据库中查出该实体,然后在做修改操作,但我们总会认为这种方法不太好,在效率上不是很高。所以我们需要找到更好的方法。

我们可以把dbContext上下文看成一个容器,当我们使用它将数据库中的数据查询出来时,它会将数据维护起来,放到容器中,但此时的数据是代理数据,而不是我们的真实数据实体。只有这样才能提高效率,我们可以打开数据库跟踪一下ef发出的sql语句,当一条实体多个字段的时候,如果你只修改一条字段的时候,sql语句也只是修改了一个字段。例如user包括name,age等字段,使用官方推荐的方法,我们想修改id=123的数据,我们先将其查询出来,这样这个实体所有的属性就有值了,当我们只将name属性修改的时候,执行saveChange时,sql语句update中只更新name,而没有更新其他字段的值,这是怎么做到的呢?对,这就是前面说到的代理类起的作用,我们假设代理类将每个属性放置一个标志,如果没有修改过该属性的值,该标志为false,否则为true。当我们更新代理类的时候上下文就可以根据标志来生成sql语句,看代码中修改方法 entry.Property("name").IsModified = true; 这句就是通过设置name属性的标志位,通知上下文,我们将name的属性改变了,所以生成的sql语句中只更新了name字段值。删除和添加同样如此,通知上下文,我们进行添加或删除操作。效率上是不是有很大的提高呢?顺便说一下,上线文的saveChanges也是提高效率的方法,该方法可以进行批处理,就是说添加多个对象的时候connection只进行一次连接,执行多条语句,可以跟踪一下数据库查看一下。其实svaeChanges也就是遍历上线文中的每个数据代理对象,看哪个对象状态是增删改方法,生成sql语句,然后一次性执行。

Entity Framework 学习第一天 续的更多相关文章

  1. Entity Framework 学习第一天

    文章是作为初学者记录之用,没有学习过的同学可以借鉴一下,至于用过和高手嘛,就算了吧.仅是入门.废话不多说了,马上新建个项目,添加Entity Framework,这个词以下将用EF代替. 本文使用的I ...

  2. Entity Framework 学习第二天 续

    今天来写一点不一样的删除,修改,查询 下面只写了几个方法 /// <summary> /// 根据删除条件进行删除 /// </summary> /// <param n ...

  3. Entity Framework 学习整理(分播客整理)

    MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...

  4. Entity Framework学习笔记

    原文地址:http://www.cnblogs.com/frankofgdc/p/3600090.html Entity Framework学习笔记——错误汇总   之前的小项目做完了,到了总结经验和 ...

  5. Entity Framework 学习中级篇1—EF支持复杂类型的实现

    本节,将介绍如何手动构造复杂类型(ComplexType)以及复杂类型的简单操作. 通常,复杂类型是指那些由几个简单的类型组合而成的类型.比如:一张Customer表,其中有FristName和Las ...

  6. Entity Framework 学习

    Entity Framework 学习初级篇1--EF基本概况 Entity Framework 学习初级篇2--ObjectContext.ObjectQuery.ObjectStateEntry. ...

  7. ADO.NET Entity Framework学习笔记(3)ObjectContext

    ADO.NET Entity Framework学习笔记(3)ObjectContext对象[转]   说明 ObjectContext提供了管理数据的功能 Context操作数据 AddObject ...

  8. Entity Framework 学习整理

    MSDN: http://msdn.microsoft.com/en-us/data/aa937723 台湾博客: http://www.dotblogs.com.tw/yc421206/ http: ...

  9. Entity Framework 学习笔记(2)

    上期回顾:Entity Framework 学习笔记(1) Entity Framework最主要的东西,就是自己创建的.继承于DbContext的类: /// <summary> /// ...

随机推荐

  1. haproxy配置文件简单管理

    版本:python3功能:对haproxy配置文件进行简单的查询.添加以及删除功能操作流程:1.根据提示选择相应的选项2.进入所选项后,根据提示写入相应的参数3.查询功能会返回查询结果,添加.删除以及 ...

  2. [设计模式 3] 用设计模式的眼光看MVC框架

    导读:之前一直在区分MVC和设计模式的区别,但是,既然有些人认为MVC是一种设计模式,那么它们之间肯定是有共通之处的.所以,本篇博客,就用设计模式的眼光来看MVC框架.仅是本人对于MVC的粗鄙看法,还 ...

  3. ng-class ionic

    我发现 ng-class="{yourclass:true,outerclass:false}" 竟然不起作用...囧.... 幸好有Google  .... <p ng-c ...

  4. 深入了解Qt(三)之元signal和slot

    深入了解Qt主要内容来源于Inside Qt系列,本文做了部分删改,以便于理解.在此向原作者表示感谢! 在Qt 信号和槽函数这篇文章中已经详细地介绍了信号和槽的使用及注意事项.在这里对其使用方面的知识 ...

  5. Linux:两台服务器之间添加信任关系,进行远程操作的时候不需要输入密码

    两台机器之间建立信任关系的步骤: 1. 在机器1上root用户执行ssh-keygen命令,生成建立安全信任关系的证书,直接Enter [root@CentOS64-x64 ~]# ssh-keyge ...

  6. su:认证失败

    使用命令[su - root]切换用户,提示[su:认证失败] 原因:Ubuntu安装之后,root用户默认是被锁定的,不允许登录,也不允许su到root. 解决:重新设置密码 在终端输入命令:sud ...

  7. 浅谈C++虚函数

    很长时间都没写过博客了,主要是还没有养成思考总结的习惯,今天来一发. 我是重度拖延症患者,本来这篇总结应该是早就应该写下来的. 一.虚函数表 C++虚函数的机制想必大家都清楚了.不清楚的同学请参看各种 ...

  8. 魔兽塔防游戏android源码

    魔兽塔防是一款经典的游戏,当年在pc机器上玩过魔兽的人应该都玩过类似的游戏,他仿照魔兽,建塔拦截敌人入侵,发挥你的智慧让敌人走最远的路,将他们消灭在路上.... 源码下载:http://code.66 ...

  9. CentOS学习笔记--时间

    时间 有装过Linux系统的人,可能都会有这样的经历,就是该机器安装windows系统时,时间正确,但是安装了linux系统后,尽管时区选择正确,也会发现系统时间不对.这是由于安装系统时采用了UTC, ...

  10. winform中嵌入Ppt、Word、Excel

    1.下载DsoFramer_KB311765_x86.exe 2.安装,默认路径安装C:\DsoFramer. 3.注册:开始菜单——>运行 输入:regsvr32 C:\DsoFramer\d ...