首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

EF简介

ORM: 广义上:ORM指的是面向对象的模型和关系型数据库的数据库之间的相互转换; 狭义上:ORM可以被认为是,基于关系型数据库的数据存储,实现一个虚拟的面向对象的数据接口。 ?...2、 //利用EF像数据库中添加一条数据 //first step:创建访问数据库的统一入口.创建EF的上下文 TestEntities dbContext...而里面的值就是我们刚才所添加的值,说明在我们执行完数据库添加操作之后,数据库里面的数据马上将我们所添加的数据马上映射给了当前的实体对象,所以当我们在下面指定需要修改的记录的主键时,如果修改和添加共用同一个对象...//利用EF像数据库中添加一条数据 //first step:创建访问数据库的统一入口.创建EF的上下文 TestEntities dbContext...3、当我们在操作完数据库对应的表示表实体后,执行dbContext.SaveChanges()后,编译器报一个实体或多个实体验证失败!

1.4K80

在Entity Framework中使用存储过程(四):如何为Delete存储过程参数赋上Current值?

一、EF存储过程参数赋值的版本策略 和传统的基于DataSet的ADO.NET类似,EF的核心功能之一就是“状态追踪(State Tacking)”。...粗略地想想,EF这样设计也无可厚非:Insert存储过程用于添加一条全新的记录,自然应该采用当前值;而Delete存储过程用于删除一条现有的记录,删除操作的筛选条件自然应该使用原始值。...是的,上一篇文章提到的逻辑删除确实也只需要传入实体属性的原始值作为Delete存储过程的参数,现在我们就举一个这样的例子。 通过是使用T_CONTACT这张简单不过的表,同样是采用逻辑删除。...不过现在有这样的一个要求,对于条存储在的记录,我们需要记录最后修改者是谁。对于一条被逻辑删除掉的记录,这个最后修改者就是删除掉该条记录的人。...这是一个很常见的需求,为此我们可以直接在T_CONTACT的数据表中添加一个新的字段:LAST_UPDATED_BY,创建该表的DDL定义如下: 1: CREATE TABLE [T_CONTACT

1.8K100
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    EF Core的增删改查

    初始化 在实际开发中,一般都是先设计好数据表再进行开发,所以很少用到EF Core的数据迁移功能。所以EF Core的初始化,一般也指的是EF Core上下文初始化。...如果需要后续变更,那么就需要在创建自定义EF Core 上下文类的时候,为之添加一个连接字符串的属性或者字段,以方便初始化的时候指定。...也就是说,如果你从EF Core的上下文获取了一个实体对象,对这个对象的某些值进行了修改。这时候EF Core其实已经记录了这个对象的修改。...如果有一条数据变更因为数据库校验或者其他约束没有通过,就会报错,同时撤销所有已推送的变更并取消后续变更的推送。...EF Core在调用 ToList的时候,会将已调用的方法和Linq转换成SQL语句,并正式向数据库发起查询。如果出现了在Linq中调用三方方法或者自己写的工具方法的话,可能会提示不受支持。

    3.2K20

    Entity Framework——性能测试

    2 查找 数据量 使用EF框架 Sql+MySql.Data.dll(简写NOEF) 结论 说明 一条 1669 170 单纯的多条查找性能基本相同...3 更新 数据量 使用EF框架 Sql+MySql.Data.dll(简写NOEF) 结论 说明 一条 112 307 总体上EF更新性能比NOEF...查得多 表已有200万数据 多条 407203 229 分析 更新一条数据EF反而比NOEF要快,但是相差也不多,可以判定性能基本一致;当更新多条时,NOEF性能明显比...相差一个数量级,然而多条操作 表已有6万数据 删除多条时,NOEF方式下一次删除2000+条记录,而EF方式下删除500条记录 多条 407203 370 分析...从NOEF方式下一次删除2000+条记录,而EF方式下删除500条记录这一结果来看,NOEF性能明显优于EF,且NOEF方式下,删除操作耗时随删除数据量平稳增长且增长率很小;但EF操作耗时随操作数据量增大而明显增大

    1.9K60

    UnitOfWork知多少

    EF中的UOW 每个DbContext类型实例都有一个ChangeTracker用来跟踪记录实体的变化。当调用SaveChanges时,所有的更改将通过事务一次性提交到数据库。...该测试用例中我们添加了一个User,并为User创建对应的Customer,同时为Customer添加一条Address。...一不做二不休,我们再对其进行一层抽象,抽离保存接口,这也就是Uow的核心接口方法。 我们抽离SaveChanges方法,定义IUnitOfWork接口。...就是整个调用链上的需要注入的同类型对象,使用是同一个类型实例。 4.7....EF和EF Core本身已经实现了Uow模式,所以在实现时,我们应避免不必要的抽象来降低系统的复杂度。 最后,重申一下: Uow模式是用来管理仓储处理事务的,仓储用来解耦的(领域层与基础设施层)。

    2.4K81

    浅析Entity Framework Core中的并发处理

    此时,将提交数据的版本数据与数据库表对应记录的当前版本信息进行比对,如果提交的数据版本号大于数据库表当前版本号,则予以更新,否则认为是过期数据。...如果一个属性被配置为并发令牌,则EF将在保存这条记录时,会检查没有其他用户修改过数据库中的这个属性的值。...2.1并发令牌在EF中工作的原理 当我们配置User中的Name为令牌的时候,EF会将并发令牌包含在Where、Update或delete命令的子句中并检查受影响的行数来实现验证。...当我们配置好上面的并发令牌时,在EF执行SaveChanges()操作并产生并发的时候,我们会得到DbUpdateConcurrencyException的异常信息,(注意:在不配置并发令牌时,这个异常一般不会触发...首先,我们添加了一条UserName为John的数据,我们在上下文中修改它为"555-555-5555", 这时候,产生并发,另一个上下文在这个SaveChang之前,就执行完成了,把值修改为了Jane

    2.8K90

    Entity Framework 并发冲突解决方案

    在大多数的应用中都会出现客户端同时发送多个请求对同一条数据就行修改,这个时候就会出现并发冲突。...我们一般的做法会有如下两种: 乐观并发 所谓的乐观并发就是多个请求同时对同一条数据的更新,只有最后一个更新请求会被保存,其他更新请求将会被抛弃。...如果利用 Entity Framework 默认的乐观并发模式,每次有并发请求购票时,每个请求都会减去门票数量,并且向数据库中插入一条购票信息,这样一来永远是最后一个请求的数据会持久化到数据库中,这样就造成了门票预约人数超过了门票的限制数量...我们需要调用集合中每个对象的 Reload 方法将数据库中最新的值放在内存中。这样后续的实体值将和数据库保持一致。完成这一步后,我们可以重新向数据库提交更新数据。...(); } } 一、方法二 上一小节中我们提到了客户端获胜、数据库获胜以及数据库和客户端合并获胜,并且讲解了原始值和更新后的数据库值以及当前值从哪里获得的。

    88020

    在Entity Framework中使用存储过程(三):逻辑删除的实现与自增长列值返回

    本篇文章通过实例的方式,讨论两个在EF使用存储过程的主题:如何通过实体和存储过程的映射实现逻辑删除;对于具有自增长类型主键的数据表,在进行添加操作的时候如何将正确的值反映在实体对象上。...将结果集的列于实体属性进行绑定 一、基于逻辑删除的数据表和存储过程定义 较之物理删除(记录彻底从数据表中清除掉),逻辑删除则继续保留该数据,只是为之进行一个删除标记,表明该记录已经被“删除”了。...实际上EF为你考虑到了这一点,你可以在直接通过EF设计器设置这样一个筛选条件。...如下图所示,我设置了筛选条件“IS_DELETED = 0”来过滤掉被逻辑删除的记录。 ? 基于上面的设置编写如下的代码,先添加3条Contact记录,然后将它们删除。...三、具有自增长列的存储过程定义 接下来我们来讨论另一个常见的场景:如果一个表中存在一个自增长列作为该表的主键,当我们通过提交对应的实体对象进行记录添加操作时,数据库中真正的键值如何返回并赋值给该实体对象

    1.7K80

    【asp.net core 系列】9 实战之 UnitOfWork以及自定义代码生成

    SaveChanges的外移 在之前介绍EF Core的时候,我们提到过使用EF需要在每次使用之后,调用一次SaveChanges将数据提交给数据库。...在实际开发中,我们不能添加一条数据或者做一次修改就调用一次SaveChanges,这完全不现实。...因为每次调用SaveChanges是EF向数据库提交变更的时候,所以EF推荐的是每次执行完用户的请求之后统一提交数据给数据库。...这样就会造成一个问题,可能也不是问题:我们需要一个接口来管理EF 的SaveChanges操作。...虽然说,EF Core约定优先,但是如果默认约定的话,得在DBContext中声明 DbSet 来声明这个字段,实体类少的话,比较简单。如果多个数据表的话,就会非常麻烦。

    62710

    EF操作数据库的步骤和一些简单操作语句

    这里是写给我自己做记录的,不会写成一篇很好的博客,也不会置顶,如果有朋友看到了,而且觉得里面的内容不咋的,希望见谅哈!...我个人还没有对EF相关的内容进行详细的整理,所以这篇随笔的参考意义不大,只是贴一些代码上去,以后有机会有时间,会对相关内容做一个总结。...使用EF操作数据库的详细步骤主要分为一下几步: 1.创建EF实体数据库模型: 在某个项目上点击右键 添加 ==》数据 ==》ADO.Net实体数据库模型 ==》然后按照提示去走; ?...(); 需要注意的是,在执行完添加操作之后,需要执行 db.SaveChanges() 操作, 这句话的意思是,把我们修改的内容更新到数据库中。...(); 好了,先简单写一下,只是草草记录,后续有时间会进行系统的归纳总结。

    1.3K20

    【我们一起写框架】领域驱动设计的CodeFirst框架(一)—序篇

    买本驱动领域的书来看?别逗了,这可不是C#语法入门,哪里有书能写明白的。 想学会领域驱动设计,只有一途——实践,不断的实践。 领域驱动设计是什么?...领域驱动设计的实现 我们即将编写的框架是基于Entity Framework的,所以越熟悉Entity Framework越好,如果你不熟悉EF,那也没关系,因为我们是从头一步一步编写的。...TableRepository文件夹:用于操作数据表。 DateBaseContext文件:管理数据库的核心文件。...当ProxyCreationEnabled属性设置为True时,我们一旦运行系统,系统会自动的,数据模型同步到数据库,并且会创建一个__MigrationHistory表,来记录同步的内容。...然后我们重写了OnModelCreating方法,在OnModelCreating里,把我们刚刚建立的映射关系添加了进去,这样数据库的表,就被我们立体的加载到了代码世界。

    57230

    .NET Core EFCore零基础快速入门简单使用

    一、什么是 Entity Framework (EF) Core Entity Framework (EF) Core 是轻量化、可扩展和跨平台版的对象关系映射程序 (O/RM)数据访问技术,。...二、EF的相关程序包 Microsoft.EntityFrameworkCore 核心程序包,封装了关键的核心代码,使用EF必须引用这个包 Microsoft.EntityFrameworkCore.Design...设计包,用于在命令行工具下EF Core开发的工具套件 Microsoft.EntityFrameworkCore.Tools 用于数据库的生成、迁移、生成表等 三、EF Core支持的数据库引擎:SqlServer...、Sqlite、PostgreSQL、MySql、Oracle等主流数据库,不同的数据库需要EF Core数据库提供程序支持。...、操作数据库表等信息 public class BloggingContext: DbContext { /// /// Blogs表的操作属性

    3K10

    【EF】DbFirst实现增删改查

    1.在VS中新建控制台应用程序 2.右击刚刚建好的程序,添加“ADO.NET实体数据模型” 3.选择“来自数据库的EF设计器” 4.依次连接服务器和数据库 5.选择包括敏感数据 6.选择实体框架...(6.x也可以试试) 7.选择需要的数据表等内容,点击完成!...这样database first的实现已经基本上完成了,如果想要用ModelFirst的方式,在第3步选择”空EF设计器模型“,在edmx文件中自己添加数据表即可。接下来通过代码来实现对数据库的操作。...1.添加实体 //所有对数据库操作的第一步就是创建数据库访问的上下文 newssystemEntities dbContext = new newssystemEntities...; //在dbContext指向的数据中的Category表添加一条数据ca dbContext.category.Add(ca);

    80010

    MVC3教程之实体模型和EF CodeFirst

    ,如果没有则有EF负责根据实体模型类创建数据库、数据表;如果存在,EF会将查询条件添加到Sql查询语句,再将Sql语句发送到数据库进行数据读取。...就会通过这段代码来添加一行数据库记录。...打开数据库,我们可以看到如下记录: ?   ...7.设置实体模型的数据验证   在ASP.NET MVC中,有一条作为核心的原则,就是DRY(“Don’t Repeat Yourself,中文意思为:不要让开发者重复做同样的事情,即“一处定义、处处可用...这是一个简单的验证设置,通过设置验证,EF还会在生成的数据库中添加验证信息,例如是否为空、字符串长度等,如果要了解更多EF的功能,请看我的另一篇随笔:Entity Framework 4.1 Code-First

    1.3K20

    .net EF 新手教程

    最近学习了.net 的EF框架,在这里自己总结一下用会的几种操作。 No.1 准备工作 首先先放上数据库的表结构,便于后面的示例操作。...下来我们在项目中添加ADO.NET实体数据模型 模型的内容根据大家的需要进行选择,我在这里选择来自数据库的EF设计器,这样他会帮我自动生成数据库中的EF设计器。...对象存在,但没有被跟踪 新创建的对象 Unchanged 对象尚未经过修改 从DbContext中读取的对象,使用Attach()方法添加的对象 ,执行SaveChanges()后的对象 Added...对象为新对象,并且已添加到对象上下文 使用Add()方法添加的对象 Deleted 对象已从上下文中删除 使用Remove方法溢出的对象 Modified 对象上的一个属性已更改 受DbContext管理...1.创建要添加修改删除的对象信息 2.改变对象状态到相应的删除添加修改状态 3.进行保存efdb.SaveChanges() 代码如下: 修改 Students objStudents

    15700

    asp.net mvc 简单项目框架的搭建过程(一)对Bll层和Dal层进行充分解耦

    学习asp.net 已经有近三个月的时间了,在asp.net mvc上花的时间最多,但个人真是有些菜,不得不说,asp.net mvc的水真的还是蛮深的。...真个架构的搭建我看了将近两遍视频,才稍稍有些头绪,今天在这里记录一下,一方面加深理解,一方面如果以后忘记了,还能快速的想起来,当然如果我的这篇简陋的随笔能有幸被有需要的人看见,并对他们产生一些帮助,我心里肯定也是非常欢欣的...(2)在Model层中新建类库 Model,然后添加EF数据库实体   添加实体的操作我就不啰嗦了,我以前的博客有讲到。结果如下: ?...1.首先在IofPf.Dal中新建UsersDal.cs文件,这个里面写对于User表的增删改查等系列数据库操作。如下入图所示: ?...且看第二个问题: (2)我们肯定不止一个文件会用到UserDal吧,实际上很多个文件都会用到UserDal。

    1K20

    EF Core 入门

    0.前言 上一章简单介绍了一下ORM框架,并手写了一个类似ORM的工具类。这一章将介绍一个在C#世界里大名鼎鼎的ORM框架——Entity Framework的Core版。...EF可以在不使用任何配置的前提下,自动解析类与表之间的映射(具体的映射逻辑与我们手写的ORM工具类一致或相近)。 自动跟踪更改。...可以延迟加载需要的数据,外键引用属性、查询结果等 丰富的映射关系,支持一对一,一对多,多对多,甚至继承、单表多实例等 可以使用Linq 进行查询 非Core版的可以通过数据库表生成实体类,两种都可以通过实体类生成表...接下来,添加 EF的SQLite包: 在非Visual Studio环境下,安装一个三方库可以使用: dotnet add package Microsoft.EntityFrameworkCore.Sqlite...这是EF Core保留的迁移记录,以便下次使用。 如果项目根目录里没有 blogging.db 这个SQLite文件的话,会自动创建该文件,同时设置好表;如果有,但不是SQLite的文件,则会报错。

    2.6K10

    EntityFramework 外键值映射

    如果在 EF OnModelCreating 中配置了实体外键映射,也就是 SQL Server 中的 ForeignKey,那么我们在添加实体的时候,主实体的主键值会自动映射到子实体的外键值,并且这个操作在一个...SaveChanges 中,但如果没有在 OnModelCreating 中进行外键映射配置,我们添加实体的时候,就不会自动映射外键值了,什么意思呢?...这种处理方式,虽然“解决”上面的问题,但其实有很多的隐患,多执行一次 SaveChanges,EF 就会多发起一次请求,增加了性能开销,并且 SaveChanges 是事务性的,如果第一个执行成功了,第二个执行失败了...,这时候第一个事务并不会回滚,因为它独立于第二个,所以,最后就会造成数据的不一致性,虽然几率非常点,但我们应该尽量避免。...在混合式框架的界面表现层,它们的数据对象的处理基本上保持和原来的代码差不多。

    4.2K50
    领券