【Entity Framework】EF中SaveChanges如何使用

2024-05-16 08:44

本文主要是介绍【Entity Framework】EF中SaveChanges如何使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【Entity Framework】EF中SaveChanges如何使用

文章目录

  • 【Entity Framework】EF中SaveChanges如何使用
    • 一、概述
    • 二、更改跟踪和SaveChanges
    • 三、SaveChanges优势
    • 四、使用SaveChanges添加数据
    • 五、使用SaveChanges更新数据
    • 六、使用SaveChanges删除数据
    • 七、单个SaveChanges中的多个操作
    • 八、备注

一、概述

虽然查询允许从数据库中读取数据,但保存数据意味着向数据库添加新实体,删除实体或以某种方法修改现有实体的属性。Entity Framework Core(EF Core)支持将数据保存到数据库。

二、更改跟踪和SaveChanges

在许多情况下,程序需要查询数据库中的某些数据,对其执行一些修改,并保存这些修改;这有时称为“工作单元”。下面示例展示我们修改的博客标题属性。在EF中,这通常按如下方式完成:

using(var context = new BloggingContext())
{var blog = context.Blogs.Single(b=>b.Title=="工蚁网络科技有限公司");blog.Title ="数字工蚁";context.SaveChanges();
}

上述代码执行一下步骤:

  1. 它使用常规LINQ查询从数据库加载实例。默认情况下跟踪EF的查询,这意味着EF在其内部更改跟踪中跟踪加载的实体。
  2. 通过分配.NET属性来照常操作加载的实体实例。此步骤不涉及EF。
  3. 最后调用DbContext.SaveChanges()。此时,EF会自动检测任何更改,方法是将实体与加载实体时的快照进行比较。检测到任何更改都将保存到数据库;使用关系数据库时,这通常涉及发送SQL,UPDATE来更新相关行。

请注意,上面描述了现有数据的典型更新操作,但添加和删除实体时遵循类似的原则。通过调用DbSet<TEntity>.AddRemove与EF的更改跟踪器交互,从而跟踪更改。然后,当调用SaveChanges()时,EF会将所有跟踪的更改应用于数据库。

三、SaveChanges优势

  • 无需编写代码来跟踪已更改的实体和属性 - EF 会自动为你执行此操作,并且仅更新数据库中的这些属性,从而提高性能。 想象一下,如果加载的实体绑定到 UI 组件,允许用户更改他们想要的任何属性;EF 减轻了找出哪些实体和属性实际已更改的负担。
  • 保存对数据库的更改有时可能很复杂! 例如,如果要添加一个博客并为该博客添加一些帖子,则可能需要为插入的博客提取数据库生成的密钥,然后才能插入帖子(因为它们需要引用博客)。 EF 为你完成所有这些操作,从而消除了复杂性。
  • EF 可以检测并发问题。例如,当其他人在你的查询和SaveChanges()之间修改了数据库行时。并发冲突中提供了更多详细信息。
  • 在支持它的数据库中,SaveChanges()自动包装事务中的多个更改,确保在发生故障时数据保存一致。
  • 在许多情况下,SaveChanges()还会对多个更改进行批处理,从而显著减少数据库往返次数并大幅提高性能。

四、使用SaveChanges添加数据

使用DbSet.Add方法添加实体类的新实例。调用DbContext.SaveChanges()时,数据将插入到数据库中:

using (var context = new BloggingContext())
{var blog = new Blog { Title = "数字工蚁" };context.Blogs.Add(blog);context.SaveChanges();
}

Add、Attach和Update方法全部呈现在传递给这些方法的实体的完整关系图上。此外,还可以使用EntityEntry.State属性仅设置单个实体的状态。如:context.Entry(blog).State = EntityState.Modified

五、使用SaveChanges更新数据

EF 将自动检测对由上下文跟踪的现有实体所做的更改。 这包括从数据库加载/查询的实体,以及之前添加并保存到数据库的实体。

只需修改分配给属性的是值,然后调用SaveChanges:

using(var context = new BloggingContext())
{var blog = context.Blogs.Single(b=>b.Title == "数字工蚁");blog.Title ="数字工蚁科技";context.SaveChanges();
}

六、使用SaveChanges删除数据

使用DbSet<TEntity>.Remove方法删除实体类的实例:

using(var context = new BloggingContext())
{var blog = context.Blogs.Single(b => b.Title == "数字工蚁");context.Blogs.Remove(blog);context.SaveChanges();
}

如果实体已在于数据库中,则将在SaveChanges期间删除该实体。如果实体尚未保存到数据库,则在调用SaveChanges时,会从上下文中删除该实体其不再插入它。

七、单个SaveChanges中的多个操作

可以将多个添加/更新/移除操作合并到对 SaveChanges 的单个调用中:

using (var context = new BloggingContext())
{// seeding databasecontext.Blogs.Add(new Blog { Url = "Goyeer数字" });context.Blogs.Add(new Blog { Url = "数字工蚁" });context.SaveChanges();
}using (var context = new BloggingContext())
{// addcontext.Blogs.Add(new Blog { Url = "Goyeer数字工蚁" });context.Blogs.Add(new Blog { Url = "工蚁数字中国" });// updatevar firstBlog = context.Blogs.First();firstBlog.Url = "";// removevar lastBlog = context.Blogs.OrderBy(e => e.BlogId).Last();context.Blogs.Remove(lastBlog);context.SaveChanges();
}

八、备注

对于大多数数据库提供程序,SaveChanges是事务性的。这意味着所有操作要么成功要么失败,绝不会部分应用这些操作。

这篇关于【Entity Framework】EF中SaveChanges如何使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994420

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

Lipowerline5.0 雷达电力应用软件下载使用

1.配网数据处理分析 针对配网线路点云数据,优化了分类算法,支持杆塔、导线、交跨线、建筑物、地面点和其他线路的自动分类;一键生成危险点报告和交跨报告;还能生成点云数据采集航线和自主巡检航线。 获取软件安装包联系邮箱:2895356150@qq.com,资源源于网络,本介绍用于学习使用,如有侵权请您联系删除! 2.新增快速版,简洁易上手 支持快速版和专业版切换使用,快速版界面简洁,保留主

如何免费的去使用connectedpapers?

免费使用connectedpapers 1. 打开谷歌浏览器2. 按住ctrl+shift+N,进入无痕模式3. 不需要登录(也就是访客模式)4. 两次用完,关闭无痕模式(继续重复步骤 2 - 4) 1. 打开谷歌浏览器 2. 按住ctrl+shift+N,进入无痕模式 输入网址:https://www.connectedpapers.com/ 3. 不需要登录(也就是

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

Windows中,.net framework 3.5安装

安装.net framework,目前已知2种方法,如下: 一、在MSDN下载对应的安装包,安装,这种可能无法安装成功,概率很大,不成功使用第二种方法,基本上没问题。 二、win8/8.1/10 下安装 .net framework 3.5.1: 1. 打开 win8/8.1/10 安装盘(这里指系统安装镜像文件),提取 sources\sxs 文件夹到 X:\sources\sxs (X代

C#中,decimal类型使用

在Microsoft SQL Server中numeric类型,在C#中使用的时候,需要用decimal类型与其对应,不能使用int等类型。 SQL:numeric C#:decimal

探索Elastic Search:强大的开源搜索引擎,详解及使用

🎬 鸽芷咕:个人主页  🔥 个人专栏: 《C++干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 引入 全文搜索属于最常见的需求,开源的 Elasticsearch (以下简称 Elastic)是目前全文搜索引擎的首选,相信大家多多少少的都听说过它。它可以快速地储存、搜索和分析海量数据。就连维基百科、Stack Overflow、

flask 中使用 装饰器

因为要完成毕业设计,我用到fountain code做数据恢复。 于是在github上下载了fountain code的python原代码。 github上的作者用flask做了fountain code的demo。 flask是面向python的一个网站框架。 里面有用到装饰器。 今天笔试的时候,我也被问到了python的装饰器。