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

Entity Framework Core 总结

migrations 命令为迁移搭建基架,以便为模型创建一组初始表 dotnet ef migrations add InitialCreate # database update 命令创建数据库并向其应用新的迁移...包管理器控制台 (PMC) 工具在 Windows 上的 Visual Studio 运行。 这些命令以动词开头,例如 Add-Migration、Update-Database。...为了跨平台 应用,同时也便于编写Shell脚本,建议使用 .NET Core CLI ,不依赖于 Visual Studio 在 ASP.NET Core 初始化数据库 这是另一种创建表结构,初始化表数据的方式...的 Razor Pages 和 Entity Framework Core - 第 1 个教程(共 8 个) | Microsoft Docs 创建数据库 Program.cs using ContosoUniversity.Data...运行应用。 EnsureCreated 创建具有新架构的数据库。 在无需保存数据的情况下,当架构快速发展时,此工作流在早期开发过程中表现良好。 如果需要保存已输入数据库的数据,情况就有所不同了。

1.1K30
您找到你想要的搜索结果了吗?
是的
没有找到

浅析Entity Framework Core的并发处理

前言 Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章.....本篇就是讲解,如何在我们的Entity Framework Core来使用和自定义我们的并发策略 2.Entity Framework Core并发令牌 要使用Entity Framework Core...的并发策略,就需要使用我们的并发令牌(ConcurrencyCheck) 在Entity Framework Core,并发的默认处理方式是无视并发冲突的,任何修改语句在条件符合的情况下,都可以修改成功...在高并发的情况下这种处理方式,肯定会给我们的数据库带来很多脏数据,所以,Entity Framework Core提供了并发令牌(ConcurrencyCheck)这个特性....这在应用中一般是可取的,以便我们的应用程序可以提示用户,在保存他们的改变之前,以确保此记录仍然代表同一个姓名的人。

2.6K90

Entity Framework Core 2.0 入门

EF Core迁移: 简单的来说就是 Model变化 --> 创建migration文件 --> 应用Migration到数据库或生成执行脚本....这个快照文件解决了老版本Entity Framework的一个顽固的团队问题. 使用迁移文件创建脚本或直接生成数据库....--verbose --verbose表示显示执行的详细过程, 其结果差不多这样: 这里的执行过程和逻辑是这样的: 如果数据库不存在, 那么efcore会在指定的连接字符串的地方建立该数据库, 并应用当前的迁移...的服务容器, 可以供注入, 同时在这里指定了Data Provider和Connection String....查询映射关联数据. 使用Select可以返回匿名类, 里面可以自定义属性. 这个匿名类只在方法内有效. 看下SQL: 可以看到SQL只Select了匿名类里面需要的字段.

3.4K140

Entity Framework Core-Migrations

使用EF Core Migrations可以使Entity & DbContext的配置与数据库保持一致,Migrations可以非常容易的将创建和更新数据库,当一个项目在开发过程时,程序员能保证实体更新...,因此他们需要运行Migration保证数据库是最新 1 如何运行Migrations 在Package Manager Console运行EF Core Migrations, 我们可以使用.NET...migration更新结束,我们会发现创建了一个新的数据库,数据库中有个表叫_EFMigrationsHistory ,该表存储了所有提交的migrations名称 4 使用 –context 关键字 如果应用程序有多个..."Address" 属性: public string Address { get; set; } 使用EF Core Migration将字段更新到Client表 PM> dotnet ef migrations...tabs=dotnet-core-cli https://www.yogihosting.com/migrations-entity-framework-core/

21740

Entity Framework Core 2.0 入门

EF Core迁移: 简单的来说就是 Model变化 --> 创建migration文件 --> 应用Migration到数据库或生成执行脚本....这个快照文件解决了老版本Entity Framework的一个顽固的团队问题. 使用迁移文件创建脚本或直接生成数据库....LearnEf.Data.csproj --verbose --verbose表示显示执行的详细过程, 其结果差不多这样: 这里的执行过程和逻辑是这样的: 如果数据库不存在, 那么efcore会在指定的连接字符串的地方建立该数据库, 并应用当前的迁移...的服务容器, 可以供注入, 同时在这里指定了Data Provider和Connection String....查询映射关联数据. 使用Select可以返回匿名类, 里面可以自定义属性. 这个匿名类只在方法内有效. 看下SQL: 可以看到SQL只Select了匿名类里面需要的字段.

3.1K80

Entity Framework Core 2.0 使用入门

一.前言 Entity Framework(后面简称EF)作为微软家的ORM,自然而然从.NET Framework延续到了.NET Core。...以前我也嫌弃EF太重而不去使用它,但是EF CoreEntity Framework Core)已经做了很多性能优化,还有一些增加新特性,吸引了我去使用它。...默认的创建数据库策略已经和EF不用,请看后面的迁移操作 三.ASP.NET Core 使用 EF Core(Code First) 1.创建一个asp.net core 2.0 mvc项目 2.通过...localhost;Port=3306;Database=WebBloggingDB; User=root;Password=;")); //配置mariadb连接字符串 } 6.在Controller获取数据库上下文...的迁移操作 前面说过,EF Core默认的创建数据库策略已经和EF不用,需要我们通过迁移来创建数据库 这里不论是控制台还是ASP.NET Core操作都是一样的,这里以ASP.NET Core作为示例

1.1K30

Entity Framework Core 2.0 新特性

前言 Entity Framework Core 2.0更新也已经有一段时间了,园子里也有不少的文章.. 看了下2.0的新特性基本算是完成了我之前发布的路线图的内容 很不错 下面就介绍一下新特性....),但在方法注册期间可以覆盖名称和模式 目前只支持标量功能 必须自行在数据库创建映射函数,EF Core迁移不会对其进行创建 2.性能提升方面 2.1DbContext连接池 在ASP.NET Core...程序我们使用EF Core一般都是将自定义DbContext类型注册到依赖注入系统,然后通过控制器的构造函数参数获取该类型的实例。...显式编译的查询API已经在以前版本的EF和LINQ to SQL可用,以允许应用程序缓存查询的翻译,以便它们只能被计算一次并执行多次。...虽然EF Core通常可以根据查询表达式的散列表示自动编译和缓存查询,但这种机制可以通过绕过哈希计算和高速缓存查找来获得小的性能增益,从而允许应用程序使用已经通过调用委托编译了查询。

3.8K90

Entity Framework Core 2.0 新特性

这样的过滤器会自动应用到任何LINQ查询所涉及的那些实体类型,包括间接引用的实体类型(对象引用,导航属性)。...这个特性的一些常见应用是: 软删除-定义一个 IsDeleted 属性 多租户-定义一个 TenantId 属性 示例代码: 1 public class BloggingContext : DbContext...在 ef core 2.0 ,我们将自定义的DbContext类型注册到DbContextPool服务,可让该数据库上下文类型的实例重复使用。...目前只支持标量函数 EF Core迁移将不负责创建它,您必须在数据库创建映射函数 九.code first 实体配置   在EF6可以通过 EntityTypeConfiguraiton 封装特定实体类型的配置代码...,在EF Core2.0,这个特性回来了(EF Core 之前的 core版本不支持)。

1.8K50

.NET 性能—Entity Framework Core调优

前言 在实际开发过程,我们遇到性能问题,常见的性能提升方案整体分为硬件、软件、网络三个方面。...按下硬件、网络不提,我们单表从程序层面对系统的性能进行优化,翻来覆去无外乎三个方面 缓存 异步 sql 本片文章,我们针对.NET Core Web项目的EF Core框架进行性能优化。...正文 1、EF Core框架已经本地缓存机制memorycache,所以我们访问一个接口,二次访问的性能相比首次会提升一大截 2、尽可能的通过主键查询 3、在进行字符串模糊查询时,分为三种情况 //StartsWith...ProductContext.Products.Where(p => p.ProductName.StartsWith("A")); //缓冲区处理(一次性将数据查出,使用result时,直接从队列取数据...数据库查询进行笛卡尔积查询,实际查询了4次 拆分查询时,EF Core会生成两个sql语句: 1、单表查询主表product 2、主表product与副表productLogs进行inner join,

22841

Entity Framework Core 之数据库迁移

前言 最近打算用.NET Core写一份开源的简易CMS系统,来练练手 所以又去深入研究了一下Entity Framework Core  发现其实有些细节园子里还是很少讲到. 特意整理了几个细节....正文 1.数据库迁移 先了解一下什么是"数据库迁移",它提供了一种方法,可以逐步将Code First的实体架构更改应用于数据库,以保持数据库与EF Core模型同步,同时保留数据库的现有数据。...我们发现Content的长度限制已经改为了50 2.删除迁移  有的时候我们刚刚创建了一个迁移,还没应用到数据库,就发现自己需要变更实体.那我们就可以删除这个没有应用的迁移版本....执行命令如下:(注意,这里是没有应用过的迁移,可以删除.如果应用过了.则会收到错误信息) Remove-Migration 3.迁移回滚. 有些时候,我们需要回滚到之前的一个迁移版本....执行如下: Update-Database 这里填写需要回滚的版本名 ,比如我们执行如下: Update-Database BanBen1 然后我们会发现,BanBen2的长度限制,已经没有了.. ?

97350

Entity Framework Core 捕获数据库变动

在实际项目中我们往往需要记录存储在数据库数据的变动(例如修改数据前记录下数据的原始值),这样一来在发生误操作时可以将数据恢复到变动前的状态,也可以追溯到数据的修改人。...如果你使用的是 Entity Framework Core 2.0 及以上版本来开发项目的话,那这个问题就好解决了。...在 Entity Framework Core ,只要捕获到了数据变更记录,我们就可以将数据随时还原到变更前的状态,在这里数据库变更记录被称为审计数据。...要解答上述两个问题,那就跟着我一起来看看怎么利用 Entity Framework Core 来捕获审计数据。...我们需要在 OnBeforSaveBehavior 方法创建 AuditDb 列表。

54810

张高兴的 Entity Framework Core 即学即用:(一)创建第一个 EF Core 应用

写在前面 Entity Framework Core (EF Core) 是 .NET 平台流行的对象关系映射(ORM)框架。...因此在项目中使用 EF Core 不一定是最优的,但一定不会错。 《张高兴的 Entity Framework Core 即学即用》系列博客将会从实践的角度去介绍 EF Core。...《张高兴的 Entity Framework Core 即学即用》系列博客共分为 4 个部分: 第一部分将从 0 开始创建一个 EF Core 应用,介绍了使用 Database First 的方式以及手工的方式生成实体类...创建一个 EF Core 应用 项目地址:https://github.com/ZhangGaoxing/ef-core-demo 项目结构 创建一个控制台应用和类库,项目结构如下: Pandemic...为控制台应用,用于实践 EF Core 的有关操作;Pandemic.Models 为类库,用于提供数据库上下文和实体类。

2.3K10

Entity Framework Core 实现MySQL 的TimeStampRowVersion 并发控制

将通用的序列号生成器库 从SQL Server迁移到Mysql 遇到的一个问题,就是TimeStamp/RowVersion并发控制类型在非Microsoft SQL Server数据库的实现。...SQL Server timestamp 是二进制数字,它表明数据库数据修改发生的相对顺序。实现 timestamp 数据类型最初是为了支持 SQL Server 恢复算法。...在Entity Framework 采用IsConcurrencyToken配置后RowVersion即自动用于where子句中用于比较Row Version, 我们也需要使用这个特性实现并发控制,Ak.Ini...的博文http://www.cnblogs.com/akini/archive/2013/01/30/2882767.html ,我们按照这篇文章的方法在Entity framework core上面解决并发控制问题...数据库表定义如下(自MySQL 5.6.5版本开始,DEFAULT CURRENT_TIMESTAMP 和 ON UPDATE CURRENT_TIMESTAMP 选项也可以应用到Datetime类型的列

1.7K80
领券