Entity Framework使用ObjectContext类

目录
  • 一、ObjectContext对象上下文
    • 1、ObjectContext和DbContext的对比
    • 2、ObjectContext类的实例封装的内容
    • 3、类的结构:
  • 二、实体对象查询:linq to Entities
    • 1、AddObject :添加实体
    • 2、DeleteObject: 删除实体
    • 3、Detach: 分离实体
    • 4、修改实体
    • 5、保存到数据库
  • 三、对象状态管理
    • 1、ObjectStateEntry对象状态实体
    • 2、ObjectStateManager对象状态管理器
  • 五、ObjectQuery对象查询
    • 1、Context.CreateQuery("esql")创建ObjectQuery。
    • 2、new ObjectQuery(ObjectContext,"esql")创建ObjectQuery
    • 3、ObjectQuery<简单类型>
    • 4、Linq查询
    • 5、ToTraceString():跟踪SQL语句
    • 6、ObjectQuery.Execute()方法
    • 7、Entity Client方式查询

一、ObjectContext对象上下文

Entity SQL 语言 - ADO.NET | Microsoft 官当文档

ObjectContext提供了管理数据的功能。

1、ObjectContext和DbContext的对比

1、从DbContext访问底层的ObjectContext

AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();
ObjectContext ctxObj = ((IObjectContextAdapter)ctxNew).ObjectContext;

2、创建ObjectSet

AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();//对象上下文
ObjectContext ctxObj = ((IObjectContextAdapter)ctx).ObjectContext;

ObjectSet objectSet = ctxObj.CreateObjectSet("Person");

2、ObjectContext类的实例封装的内容

ObjectContext 封装.NET Framework和数据库之间的连接。此类用作“创建”、“读取”、“更新”和“删除”操作的网关。

ObjectContext是一个类,用于管理所有数据库操作(如数据库连接),并管理实体模型的各种实体。我们可以说ObjectContext是访问或与概念模型中定义的实体一起工作的主要类。

  • 到数据库的连接,以 EntityConnection 对象的形式封装。
  • 描述该模型的元数据,以 MetadataWorkspace 对象的形式封装。
  • 用于管理缓存中持久保存的对象的 ObjectStateManager 对象。

3、类的结构:

ObjectContext类的成员方法

  • Attach(string,object):将实体对象附加到指定的实体容器中
  • AddObject(string,object):将实体对象添加到制定的实体容器中
  • Detach(object):移除指定的实体对象
  • DeleteObject(object):删除指定的实体对象
  • GetObjectByKey(System.Data.EntityKey key):通过主键KEY从ObjectStateManager中检索对象(如果存在);否则从存储区中检索。
  • TryGetObjectByKey(System.Data.EntityKey,out object):尝试从指定实体主键返回该实体
  • ApplyPropertyChanges(string,object):将以指派的实体对象属性的更改应用到容器中对应的原对象。
  • AcceptAllChanges():接受所有对该实体对象的更改
  • SaveChanges(bool):将所有更新持久保存到存储区中。参数是客户端事务支持所需的参数。参数为true则在更新后自动将更改应用到ObjectStateManager中的实体。如果为false,则在更新后还需要调用AcceptAllChanges()以便更新ObjectStateManager中的实体。
  • Refresh(System.Data.Objects.RefreshMode refreshMode, object entity):按指定持久更新模式,使用指定实体的存储区数据更新ObjectStateManager。
  • CreateQuery(string,params ObjectParameter[]):从给定的查询字符串创建ObjectQuery对象。
  • ExecuteFunction(string,params ObjectParameter[]):对默认容器执行给定的函数。

二、实体对象查询:linq to Entities

并非所有的LINQ标准查询运算符都支持 linq to Entities 查询。

1、AddObject :添加实体

将实体添加到集合中,创建实体时,状态为EntityState.Detached。

当调用AddObject将实体添加到Context时,状态为EntityState.Added

myContext context = new myContext();
myTab r = new myTab();
r.ID = 10;
r.a = "wxwinter";
Console.WriteLine(r.EntityState); //print:Detached
context.AddTomyTab(r);
Console.WriteLine(r.EntityState); //print:Added
context.SaveChanges();

myContext context = new myContext();
myTab newrow = new myTab() { a = "wxd", b = "lzm", c = "wxwinter" };
context.AddObject("myTab",newrow);
context.SaveChanges();

2、DeleteObject: 删除实体

将集合中的实体添标记为删除。

当调用Context.DeleteObject时,并不是将实体移除集合,而是将实体添标记为EntityState.Deleted ,在下次调用SaveChanges()方法时跟新数据库

myContext context = new myContext();
myTab r = context.myTab.First(p=>p.ID==1);
Console.WriteLine(r.EntityState); //print:Unchanged
context.DeleteObject(r);
Console.WriteLine(r.EntityState); //print:Deleted
context.SaveChanges();

3、Detach: 分离实体

将实体从Context中分离,将状态标记为EntityState.Detached 。

myContext context = new myContext();
myTab r = myTab.CreatemyTab(22);
Console.WriteLine(r.EntityState); //print:Detached
context.AddTomyTab(r);
Console.WriteLine(r.EntityState); //print:Added
context.Detach(r);
Console.WriteLine(r.EntityState); //print: Detached

4、修改实体

可以直接修在实体对象上修改。

当修改在Context中的实体时,会将实体的状态标记为EntityState.Modified

myContext context = new myContext();
myTab r = context.myTab.First(p=>p.ID==1);
Console.WriteLine(r.EntityState); //print:Unchanged
r.a = "wxwinter";
Console.WriteLine(r.EntityState); //print:Modified
context.SaveChanges();

5、保存到数据库

int changes = 0;
try
{
    changes += ctx.SaveChanges();
}
catch (OptimisticConcurrencyException ex)
{
    ctx.Refresh(System.Data.Objects.RefreshMode.ClientWins, ex.StateEntries);
    changes += ctx.SaveChanges();
}
Console.WriteLine("实体改变数量" + changes);

三、对象状态管理

1、ObjectStateEntry对象状态实体

ObjectStateEntry维护实体实例或关系实例的状态(已添加、已删除、已分离、已修改或未更改)、键值和原始值。还管理已修改属性的列表。

其包含以下方法:

  • AcceptChanges():接受当前值作为原始值,并将实体标记为Unchanged()。
  • Delete():将实体标记为Deleted()。如果实体处于Added()()()状态,它将为Detached()。
  • GetModifiedProperties():返回标记为Modified()的属性名称。
  • SetModified():将状态设置为Modified()。
  • SetModifiedProperty():将指定的属性标记为Modified()。

2、ObjectStateManager对象状态管理器

ObjectStateManager用于维护对象映射、对象状态/标识管理以及实体实例或关系实例的持久性。

1、GetObjectStateEntries:获取给定EntityState的ObjectStateEntry集合。

IEnumerable<ObjectStateEntry> oseList = ctx.ObjectStateManager.GetObjectStateEntries(EntityState.Added);
foreach (ObjectStateEntry ose in oseList)
{
    Console.WriteLine("{0},{1},{2},{3}", ose.State, ose.CurrentValues["ID"], ose.EntitySet.Name, ose.Entity);
}

2、GetObjectStateEntry:获取给定的EntityKey对应的ObjectStateEntry

myContext ctx = new myContext();
myTab r = ctx.myTab.First(p => p.ID == 1);
r.a = "wxwinter";
ObjectStateEntry ose = context.ObjectStateManager.GetObjectStateEntry(r.EntityKey);

Console.WriteLine(ose.State);
foreach (string pr in ose.GetModifiedProperties())
{
    Console.WriteLine(pr);
    Console.WriteLine("CurrentValues :{0}", ose.CurrentValues[pr]);
    Console.WriteLine("OriginalValues:{0}", ose.OriginalValues[pr]);
}

五、ObjectQuery对象查询

  • ObjectQuery 提供了一个管理[实体对象]集合的方法。
  • ObjectQuery对ObjectContext进行了封装。

可以在对象查询中使用esql

  • e关键字:“e”出现在 ESQL 中, 由 ObjectQuery.Name 属性设定,用于标示源查询对象(ObjectQuery)的名称,可以将这个默认值 "e" 改成其他字符串。
  • value关键字:value后只能返回一个成员。
  • 查询参数:ObjectParameter v1 = new ObjectParameter("v1", 3);

访问方式

1、Context.CreateQuery("esql")创建ObjectQuery。

可以通过ObjectContext.CreateQuery("esql")的方式创建ObjectQuery。

AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();//对象上下文
ObjectContext ctxObj = (ctx as IObjectContextAdapter).ObjectContext;
// ObjectQuery query = new ObjectQuery("select * from..", ctxObj);
ObjectQuery queryTab = ctxObj.CreateQuery("select  value e  from Person as e  where e.FirstName like 'A%'");
Console.WriteLine(queryTab .ToTraceString());
foreach (Person r in queryTab )
{
    Console.WriteLine(r.FirstName);
}

2、new ObjectQuery(ObjectContext,"esql")创建ObjectQuery

可以通过new ObjectQuery(ObjectContext,"esql")的方式创建ObjectQuery,会跟据SQL字串的不同,得到具体的ObjectQuery<值类型>,或ObjectQuery或ObjectQuery<实体>

string econString = @"metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string=""data source=(LocalDb)\v11.0;initial catalog=AdventureWorks2012;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework""";
EntityConnection econ = new EntityConnection(econString);
ObjectContext ctxObj = new ObjectContext(econ);//使用ObjectContext封装EntityConnection
ObjectQuery queryTab = new ObjectQuery("select  e.FirstName,e.LastName  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'", ctxObj );

foreach (var r in queryTab)
{

    System.Console.WriteLine("{0},{1}", r[0].ToString(), r[1].ToString());

}

3、ObjectQuery<简单类型>

ObjectQuery<int> queryTab = new ObjectQuery<int>("select value Count(e.BusinessEntityID) from AdventureWorks2012Entities.Person as e", ctxObj );
foreach (var r in queryTab)
{
    System.Console.WriteLine("个数:{0}", r.ToString());
}

4、Linq查询

ObjectQuery queryTab = ctxObj.CreateQuery("select  value e  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'");//这以后的linq查询条件可合并为一个SQL
IQueryable queryTab2 = queryTab.Where(p => p.FirstName.StartsWith("A")).OrderBy(p => p.LastName);
foreach (var r in queryTab2)
{
    System.Console.WriteLine("{0},{1}", r.FirstName, r.LastName);
}

5、ToTraceString():跟踪SQL语句

这个方法用于追踪所执行的SQL语句,通过此方法我们可以获取所执行的SQL语句,以便我们查看、分析具体执行的SQL语句。

6、ObjectQuery.Execute()方法

返回ObjectResult结果集

ObjectQuery queryTab = ctxObj .CreateQuery("select  value e  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'");
ObjectResult resultTab = queryTab.Execute(MergeOption.NoTracking);
foreach (var r in resultTab)
{
    System.Console.WriteLine("{0},{1}", r.FirstName, r.LastName);
}

7、Entity Client方式查询

不需要使用ObjectContext实例!! Entity Client使用esql。

//不需要使用ObjectContext实例!!

string esql = "select  value e  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'";//获取所有列,不能使用Select *
 EntityConnection conn = new EntityConnection("name=AdventureWorks2012Entities");
 conn.Open();
 EntityCommand cmd = conn.CreateCommand();
 cmd.CommandText = esql;
 EntityDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);
 while (dr.Read())
 {
     MessageBox.Show(dr.GetValue(0) + "," + dr.GetValue(1));
 }

到此这篇关于Entity Framework使用ObjectContext类的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Entity Framework模型优先与实体对象查询

    目录 一.概念: 1.EF6 可实现的功能: 二.安装Entity Framework6 1.VS2019 Installer安装“Entity Framework6 工具” 2.通过Nuget安装“Entity Framework”: 三.新建ObjectContext 和EntityObject 1.“根据模型生成的数据库”的设计器功能实现ModelFirst. 四.实体对象查询:linq to Entities 1.使用lambda表达式查询 2.执行存储过程(通过“添加”-----”函数

  • Entity Framework Core种子数据Data-Seeding

    目录 一.什么是Data-Seeding 二.初始化方法 1.模型中配置 2.手动迁移时添加 3.自定义初始化逻辑 三.Data-Seeding本质 1.首次迁移 2.修改不是主键的数据 3.删除数据 4.修改主键数据 四.总结 一.什么是Data-Seeding Data-Seeding是EntityFrameworkCore 2.1以上版本新增加的特性.在项目刚开始的时候,我们往往是需要初始化一些基础数据到数据库中,通过Data-Seeding特性就可以实现这一功能.本篇文章我们将讲解如何进

  • Entity Framework Core生成数据库表

    目录 一.引言 二.具体示例 1.代码生成 2.程序包管理器控制台迁移 1.安装Microsoft.EntityFrameworkCore.Tools包 2.添加迁移命令 3.更新数据库 3.命令行迁移 1.添加迁移 2.更新数据库 三.总结 一.引言 生成数据库表有下面的三种方式: 代码生成. 程序包管理器控制台迁移. 命令行迁移. 下面分别介绍上面的三种方法. 二.具体示例 1.代码生成 在程序里面执行下面的代码可以在运行时生成数据库: dbContext.Database.EnsureCr

  • Entity Framework Core基于数据模型创建数据库

    1.简介 使用Entity Framework Core构建执行基本数据访问的ASP.NET Core MVC应用程序.使用迁移(Migrations)基于数据模型创建数据库,你可以在Windows上使用Visual Studio 2017 PowerShell或在Windows.macOS或Linux上使用.NET Core CLI来学习创建数据库. 2.创建新项目 2.1系统必备 在创建新项目之前都要检查是否安装以下软件:●具有以下工作负载的Visual Studio 2017 15.7版或

  • Entity Framework Core更新时间映射

    时间字段 在真实的开发中,为了跟踪数据的变化,一般会在数据表里面有CreatedTime和UpdatedTime两列.CreatedTime表示创建时间,新增一条数据的时候,会更新CreatedTime列的值.UpdatedTime表示更新时间,更新数据的同时也会更新UpdatedTime列的值,这时候就需要对应的映射来配置.我们修改Blog类,增加这两个时间字段: using System; namespace EFCore.Model { public class Blog { public

  • 对Entity Framework Core进行单元测试

    一.引言 我们先来讲解如何对EntityFrameworkCore进行单元测试,这里我们使用内存数据库进行测试.使用内存数据库需要安装Microsoft.EntityFrameworkCore.InMemory这个包. 二.创建测试项目 我们还是以上面文章中创建的项目为例,在解决方案中添加一个测试项目,这里选择使用xUnit作为测试项目: 创建完成后的项目结构如下图所示: 我们首先在EFCoreTest项目中安装Microsoft.EntityFrameworkCore和Microsoft.En

  • Entity Framework Core表名映射

    表名映射 我们知道:如果是在默认情况下,使用EFCore Code First的方式生成的表名跟数据上下文类中定义的实体属性的名称是一致的,例如: public DbSet<Blog> Bloges123 { get; set; } 这里定义的属性名称是Bloges123,那么最后数据库中生成的表名也叫Bloges123.看下面的测试. 我们首先添加迁移,每次迁移都会生成一个对应的迁移记录类,代码如下图所示: 可以看到,这里显示创建表的名称就是Bloges123.最后更新数据库,更新完成以后查

  • Entity Framework使用ObjectContext类

    目录 一.ObjectContext对象上下文 1.ObjectContext和DbContext的对比 2.ObjectContext类的实例封装的内容 3.类的结构: 二.实体对象查询:linq to Entities 1.AddObject :添加实体 2.DeleteObject: 删除实体 3.Detach: 分离实体 4.修改实体 5.保存到数据库 三.对象状态管理 1.ObjectStateEntry对象状态实体 2.ObjectStateManager对象状态管理器 五.Obje

  • Entity Framework映射TPH、TPT、TPC与继承类

    目录 一.TPH 1.默认行为 2.Fluent API修改默认行为 二.TPT 1.默认行为 2.Fluent API修改默认行为 三.TPC 1.默认行为 2.Fluent API修改默认行为 四.实体拆分 五.表拆分 六.将类指定为复杂类型 1.指定方法: 2.配置复杂类型的属性 七.DataBase初始化 1.调用Database.SetInitializer方法: 2.通过配置文件更灵活的指定数据库初始化的方式: 3.自定义数据库初始化类 一.TPH Table Per Hierarc

  • Entity Framework系统架构与原理介绍

    一.Entity Framework概要 Entity Framework是微软的Object Relational Mapper(对象关系映射),也就是我们平常说的ORM,它可以让应用程序开发者将关系型数据作为业务模型来使用,也消除了开发者为数据访问编写的绝大多数管道代码的需要(比如使用ADO.NET).Entity Framework提供了一个综合的.基于模型的系统,通过摆脱为所有的领域模型编写相似的数据访问代码,使得开发者创建数据访问层是如此之简单.Entity Framework的首发版

  • Entity Framework代码优先(Code First)模式

    目录 一.Code First 代码优先 二.创建或生成Model代码 1.从数据库生成Model代码 2.手工创建Model代码 三.配置文件 四.操作 1.添加单个实体,Add 2.修改 3.删除,Remove 五.查询 1.Load(): 2.ToList(): 3.Find(): 4.Single().SingleOrDefault().First()等: 六.直接执行SQL语句 1.在实体上运行SQL命令, 2.在Database属性上运行SQL命令 一.Code First 代码优先

  • 基于Entity Framework自定义分页效果

    简介 之前写个一个基于Dapper的分页实现,现在再来写一个基于Entity Framework的分页实现,以及增删改的通用实现. 代码 还是先上代码:https://github.com/jinweijie/EF.GenericRepository 如何运行示例 还是像先前一样: 1. 先Clone下代码,在Database里面解压缩Database.7z 2. Attach到Sql Server LocalDB上.如果你用的不是Sql Server的LocalDB,你需要更改App.Conf

  • C# Entity Framework中的IQueryable和IQueryProvider详解

    前言 相信大家对Entity Framework一定不陌生,我相信其中Linq To Sql是其最大的亮点之一,但是我们一直使用到现在却不曾明白内部是如何实现的,今天我们就简单的介绍IQueryable和IQueryProvider. IQueryable接口 我们先聊聊这个接口,因为我们在使用EF中经常看到linq to sql语句的返回类型是IQueryable,我们可以看下这个接口的结构: 复制代码 代码如下: public interface IQueryable : IEnumerab

  • C#中Entity Framework常见报错汇总

    以下小编整理的Entity Framework常见错误的汇总,大家如果还有不明白可以在下面留言区讨论. 1 实体属性配置为IsRequired()对更新的影响 抛出异常类型DbEntityValidationException 表结构: 实体: public class User { public int Id { get; set; } /// <summary> /// 账号 /// </summary> public string Account { get; set; }

  • c# 使用Entity Framework操作Access数据库的示例

    Entity Framework是C#开发中最常见的ORM工具.默认Entity Framework只提供支持MSSQL的provider factory.但是开发者开源贡献了对SQLite.MySql以及Access等的支持. Entity Framework将概念模型中定义的实体和关系映射到数据源,利用实体框架可以将数据源返回的数据具体化为对象:跟踪对象所做的更改:并发处理:将对象更改传播到数据源等.今天我们就一起讨论如何利用Entity Framework进行查询.插入.更新和删除数据.

  • Entity Framework Core生成列并跟踪列记录

    注意:我使用的是 Entity Framework Core 2.0 (2.0.0-preview2-final).正式版发布时,功能可能存在变动. 当您设计数据库时,有时需要添加列以跟踪记录何时更改,以及谁进行了更改.例如,您添加以下列: CreatedAt CreatedBy LastUpdatedAt LastUpdatedBy 您可以轻松地使用默认值和触发器来处理CreatedAt和LastUpdatedAt列.老实说,创建触发器是件无聊的事情,你也不想自己做.此外,很难设置用户名,因为

随机推荐