Find,AsNoTracking,Attach,DBEntityEntry,ChangeTracker,Local

一:DBSet

我们在SaveChange的时候,如果获取到DbSet中一些Entity的变化。。。。

二:我们如果动态的detect这些entity的变化。。。

1. DBEntityEntry.... 可以获取的到某一个entity的实时状态。。。

db.Entry => 它的result类型。。

《1》 可以被detect entity的哪些属性:

State: Modified

OriginalValues: myentity.OriginalValues["StudentName"]

CurrentValues: myentity.CurrentValues["StudentName"]

2. ChangeTracker: 可以获取得到当前dbcontext下面的所有entity的变化。。。。

result类型就是 IEnumerable<DbEntityEntry>

{System.Data.Entity.Infrastructure.DbEntityEntry}
CurrentValues: {System.Data.Entity.Infrastructure.DbPropertyValues}
Entity: {ConsoleApplication30.Student}
InternalEntry: {System.Data.Entity.Internal.InternalEntityEntry}
OriginalValues: “(entityList.FirstOrDefault()).OriginalValues”引发了类型“System.InvalidOperationException”的异常
State: Added
_internalEntityEntry: {System.Data.Entity.Internal.InternalEntityEntry}

using (SchoolDBEntities db = new SchoolDBEntities())
{
//update操作
var item = db.Students.FirstOrDefault();
item.StudentName = "张三";

//add操作
db.Students.Add(new Student() { StudentName = "王五" });

//删除操作
var myitem = db.Students.FirstOrDefault(i => i.StudentID == 3);
db.Students.Remove(myitem);

//检测到当前db下面所有被跟踪的实体
var entityList = db.ChangeTracker.Entries();

foreach (var entity in entityList)
{

}
}

从这个例子中,我们可以看到,确实可以跟跟踪,方便我们去检测entity的状态。。。。

三:Local

这个Local只跟踪CUR操作。。。 ChangeTracker有一点点不一样。。。

Local只能针对某一个DBset而言。。。

ChangeTracker可以跟踪整个DbContext。。。。

Entry 只能跟踪某一个实体。。。

四:看一下DBSet下面的其他属性

using (SchoolDBEntities db = new SchoolDBEntities())
{
//update操作
var item = db.Students.FirstOrDefault();
item.StudentName = "张三";

//add操作
db.Students.Add(new Student() { StudentName = "王五" });

//删除操作
var myitem = db.Students.FirstOrDefault(i => i.StudentID == 3);
db.Students.Remove(myitem);

foreach (var mylocal in db.Students.Local)
{

}

////检测到当前db下面所有被跟踪的实体
//var entityList = db.ChangeTracker.Entries();

//foreach (var entity in entityList)
//{

//}
}

1. AsNoTracking()

using (SchoolDBEntities db = new SchoolDBEntities())
{
//update操作
var item = db.Students.AsNoTracking().FirstOrDefault();
item.StudentName = "张三";

var item2 = db.Students.FirstOrDefault();
item2.StudentName = "李四";

var track1 = db.Entry(item);

var trace2 = db.Entry(item2);
}

track1
{System.Data.Entity.Infrastructure.DbEntityEntry`1[ConsoleApplication30.Student]}
CurrentValues: “track1.CurrentValues”引发了类型“System.InvalidOperationException”的异常
Entity: {System.Data.Entity.DynamicProxies.Student_3D2C2AEAA0104FF4F10F5ECE055C297922EDA7306BF72635BE0EE3A849DCA14A}
OriginalValues: “track1.OriginalValues”引发了类型“System.InvalidOperationException”的异常
State: Detached
_internalEntityEntry: {System.Data.Entity.Internal.InternalEntityEntry}
trace2
{System.Data.Entity.Infrastructure.DbEntityEntry`1[ConsoleApplication30.Student]}
CurrentValues: {System.Data.Entity.Infrastructure.DbPropertyValues}
Entity: {System.Data.Entity.DynamicProxies.Student_3D2C2AEAA0104FF4F10F5ECE055C297922EDA7306BF72635BE0EE3A849DCA14A}
OriginalValues: {System.Data.Entity.Infrastructure.DbPropertyValues}
State: Modified
_internalEntityEntry: {System.Data.Entity.Internal.InternalEntityEntry}

DbSet仓储模式自带的一个Find操作。。。

//update操作
var item = db.Students.Find(2);

DbSet中Find,AsNoTracking,Attach及DBEntityEntry,ChangeTracker的更多相关文章

  1. EF DBContext中DbSet中Hashset添加对象后,DataGrid UI没有刷新的问题

    使用EF4/5添加数据库视图生成DBContext,如果数据表/对象之间有M-N对应关系,EF对自动添加引用类集合,是Hashset类型.由于不是ObservableCellection类型,在引用类 ...

  2. 在Parallel中使用DbSet.Add()发现的一系列多线程问题和解决过程

    发现问题 需求很简单,大致就是要批量往数据库写数据,于是打算用Parallel并行的方式写入,希望能利用计算机多核特性加快程序执行速度.想的很美好,于是快速撸了类似下面的一串代码: using (va ...

  3. EntityFramework Core 1.1 Add、Attach、Update、Remove方法如何高效使用详解

    前言 我比较喜欢安静,大概和我喜欢研究和琢磨技术原因相关吧,刚好到了元旦节,这几天可以好好学习下EF Core,同时在项目当中用到EF Core,借此机会给予比较深入的理解,这里我们只讲解和EF 6. ...

  4. easyui datagrid 禁止选中行 EF的增删改查(转载) C# 获取用户IP地址(转载) MVC EF 执行SQL语句(转载) 在EF中执行SQL语句(转载) EF中使用SQL语句或存储过程 .net MVC使用Session验证用户登录 PowerDesigner 参照完整性约束(转载)

    easyui datagrid 禁止选中行   没有找到可以直接禁止的属性,但是找到两个间接禁止的方式. 方式一: //onClickRow: function (rowIndex, rowData) ...

  5. Repository模式中,Update总是失败及其解析

    在Repository模式中,我的Update方法总是无法更新实体,这个非常郁闷,Update方法如下: 1: public virtual void Update(T entity) 2: { 3: ...

  6. Repository模式中,Update总是失败及其解析(转)

    出处:http://www.cnblogs.com/scy251147/p/3688844.html 关于Entity Framework中的Attached报错的完美解决方案终极版 前发表过一篇文章 ...

  7. EntityFramework 学习 一 DbSet

    DBSet类表示一个实体的集合,用来创建.更新.删除.查询操作,DBSet<TEntity>是DBSet的泛型版本 你可以使用DbContext获取DBSet的引用,例如dbContext ...

  8. EF中加载实体的方式

    EF中的查询执行时机:1. foreach进行枚举2. ToArray.ToList.ToDictionary3. Linq的一些操作,如First.Any4. DbSet上的Load操作.DbEnt ...

  9. EF中的EntityState几个状态的说明

    之前使用EF,我们都是通过调用SaveChanges方法把增加/修改/删除的数据提交到数据库,但是上下文是如何知道实体对象是增加.修改还是删除呢?答案是通过EntityState枚举来判断的,我们看一 ...

随机推荐

  1. vue-cli 自定义过滤器的使用

    vue-cli 自定义过滤器的使用 vue2.0将内置过滤器去除,所以过滤器需要自己编写. Vue.js 允许你自定义过滤器,可被用作一些常见的文本格式化.过滤器可以用在两个地方:mustache 插 ...

  2. RHCE7 学习里程-1.配置IP,DNS

    一.安装系统完成 1.系统安装完成之后不同于 6 的 ifconfig 命令.7 使用ip add ,这个跟网络设备配置端口IP 有点类似. 使用  ip add  查看网卡编号 cd  /etc/s ...

  3. AndroidManifest.xml中声明权限——各种permission含义摘录

    android.permission.EXPAND_STATUS_BAR 允许一个程序扩展收缩在状态栏,android开发网提示应该是一个类似Windows Mobile中的托盘程序 android. ...

  4. SVN 与Git的区别

    1:最主要的区别是Git是分布式版本控制系统,而SVN是集中式的版本控制系统.能理解这一点,区别它们就会容易很多,Git并不是目前唯一的分布式版本控制系统,比如还有Mercurial等.不过话说回来G ...

  5. android学习-Eclipse中修改Android项目图标

    参考原文:http://blog.csdn.net/wpwbb510582246/article/details/52556753 方法一:替换res文件夹下的ic_launcher-web.png图 ...

  6. <mvc:annotation-driven />讲解

    <mvc:annotation-driven />是一种简写形式,完全可以手动配置替代这种简写形式,简写形式可以让初学者快速应用默认配置方案.<mvc:annotation-driv ...

  7. 读取properties文件并获取属性值

    1.Properties与ResourceBundle 两个类都可以读取属性文件中以key/value形式存储的键值对,ResourceBundle读取属性文件时操作相对简单. 2.Propertie ...

  8. Jenkins + Jmeter +Ant自动化集成环境搭建(一)

    所需工具 一.jmeter 工具下载 https://jmeter.apache.org/  配置环境JDK等及各种插件可以看小七之前的教程 二.Ant安装(http://ant.apache.org ...

  9. ubuntu Qt5 librealsense opencv

    08:11:47: 进程"/usr/bin/make"正常退出. 08:11:47: 配置没有改变, 跳过 qmake 步骤. 08:11:47: 正在启动 "/usr/ ...

  10. IIS网站最大并发连接数

    打开网站服务器IIS---[控制面板]-[管理工具]--[Internet信息服务IIS管理器]   打开应用程序池--找到网站对应使用的应用程序池--选择右侧[高级设置]   在[高级设置]窗口可看 ...