現在、EF Core の最新バージョンは 2.0.0-priview1-final
であるため、この記事では主にこのバージョンのいくつかの手順について説明します。 2.0.0-priview1-final
,所以本篇文章主要是针对此版本的一些说明。
注意:如果你要在Visual Studio 中使用 .NET Core 2.0 , 你需要至少 Visual Studio 2017 15.3 预览版本。
相关mysql视频教程推荐:《mysql教程》
你可以通过以下命令来安装或者升级你目前的 .NET Core 版本。
// 安装 PM> install-package Microsoft.EntityFrameworkCore.SqlServer -Pre -Version 2.0.0-preview1-final // 升级 PM> update-package Microsoft.EntityFrameworkCore.SqlServer -Pre -Version 2.0.0-preview1-final
工具包
// 直接修改 CSPROJ 文件 <ItemGroup> <DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0-preview1-final" /> </ItemGroup> // 或者通过以下命令 PM> update-package Microsoft.EntityFrameworkCore.Tools -Pre -Version 2.0.0-preview1-final
避免创建不必要的子查询
一些命令将切换到客户端进行执行
只有少数请求才会检索表的所有列
有事没有适当的过滤条件,将单个LINQ 查询转换为 N + 1 查询。
在 EF Core 2.0 中添加了 EF.Functions 属性,EF Core Provider 可以使用它们来自定义一些映射到数据库函数后者运算符的方法,以便于在 LINQ 查询中调用它们。如:
var aCustomers = from c in context.Customers where EF.Functions.Like(c.Name, "a%"); select c;
分离实体和表什么意思呢?在以前,一个数据库表会映射到 EF 中的一个实体对象,也就是表和实体是一一对应的关系。那么在 2.0 版本中,允许映射一些关联的实体到一个表中,并且EF会维护这些实例或者引用关系。
modelBuilder.Entity<Customer>() .OwnsOne(c => c.WorkAddress);public class Customer { public int CustomerId { get; set; } public Address WorkAddress { get; set; } }public class Address { public string Line { get; set; } public string PostalOrZipCode { get; set; } public string StateOrProvince { get; set; } public string CityOrTown { get; internal set; } }
在生成数据库表的时候,Customer
和 Address
将生成为一个表。
注意:priview1 中此功能暂不完整。
新版本引入了一个叫做“垂直过滤”的一个功能,这是一个比较常见的需求。
在我们定义EF Core上下文模型的时候,可以在模型创建的时候附加一些过滤条件,比如在查询的时候总是过滤掉一些“逻辑删除”的数据。
public class BloggingContext : DbContext { public DbSet<Blog> Blogs { get; set; } public DbSet<Post> Posts { get; set; } public int TenantId {get; set; } protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity<Post>() .HasQueryFilter(p => !p.IsDeleted && p.TenantId == this.TenantId ); } }
当通过直接查询或者导航属性(Include()
)查询类型数据时,将会自动应用此过滤条件。当然你可以使用 IgnoreQueryFilters()
インストールまたはアップグレードEF Core 2.0 へ
次のコマンドを使用して、現在の .NET Core バージョンをインストールまたはアップグレードできます。
services.AddDbContextPool<BloggingContext>( options => options.UseSqlServer(connectionString));
ツールキット
private static Func<CustomerContext, int, Customer> _customerById = EF.CompileQuery((CustomerContext db, int id) => db.Customers .Include(c => c.Address) .Single(c => c.Id == id)); ...using (var db = new CustomerContext()) { var customer = _customerById(db, 147); }
EF Core 2.0の新機能
不必要なサブクエリの作成を避ける
一部のコマンドは、実行のためにクライアントに切り替えます
適切なフィルター条件なしで単一の LINQ クエリが実行される場合があります N に変換します+1 クエリ。
EF.Functions.Like()
EF Core 2.0 に EF.Functions プロパティが追加されました。EF Core Provider はそれらを使用して、データベース関数と後者の演算子にマップするいくつかのメソッドをカスタマイズできます。これらは LINQ クエリで呼び出すことができます。例:
rrreee
エンティティとテーブルを分離するとはどういう意味ですか?以前は、データベース テーブルは EF のエンティティ オブジェクトにマップされていました。つまり、テーブルとエンティティの間には 1 対 1 の対応関係がありました。その後、バージョン 2.0 では、いくつかの関連エンティティをテーブルにマップすることが許可され、EF はこれらのインスタンスまたは参照関係を維持します。
データベーステーブルを生成する際、Customer
と Address
が 1 つのテーブルとして生成されます。
Include()
) を通じて型データをクエリするときに自動的に適用されます。もちろん、 IgnoreQueryFilters()
を使用して、クエリ内でこのグローバル フィルターを無効にすることができます。 🎜🎜DbContext 接続プール🎜🎜通常、ASP.NET Core で EF Core を使用するには、DbContext のカスタマイズが含まれます。DbContext はシステム コンテナーに挿入され、コントローラーのコンストラクターを通じてコンテナーからオブジェクト インスタンスが取得されます。これは、🎜リクエストごと🎜に新しいインスタンスが作成されることを意味します。 🎜🎜 EF Core 2.0 では、カスタム DbContext を注入する新しい方法が導入され、インスタンス プールを明示的に使用してコンテナーに注入します。 🎜rrreee🎜このメソッドを使用すると、コントローラーが DbContext インスタンスをリクエストすると、まずプール内に使用可能なインスタンスがあるかどうかが確認され、リクエストが処理されると、インスタンスに関連付けられている状態がすべてリセットされ、その後インスタンスがリセットされます。プールに戻ります。 🎜🎜この概念は ADO.NET のデータベース接続プールに似ており、DbContext インスタンスの初期化コストを節約できるという利点があります。多くの ASP.NET Core アプリケーションは、このアプローチを使用してパフォーマンスを向上させることができます。 🎜🎜クエリを手動でコンパイルする🎜🎜 EF と Linq to SQL の以前のバージョンには、クエリを手動または明示的にコンパイルするための API があり、アプリケーションは変換されたクエリをキャッシュして、クエリを 1 回だけコンパイルして複数回実行することができました。 -レート。 🎜🎜EF Core はクエリ式に基づいてクエリを自動的にコンパイルしてキャッシュできますが、このメカニズムではハッシュ計算やキャッシュをバイパスすることでクエリのパフォーマンスが若干向上します。これにより、アプリケーションは Inquire 呼び出しを通じてコンパイルされたデリゲート チェーンを使用できるようになります。 🎜rrreee🎜その他🎜🎜EF Core 2.0 では、一部のログ記録と診断インフラストラクチャに大きな調整が加えられ、Azure Application Insights との統合も行われます。 🎜🎜遅延読み込みの追加はまだ議論中であり、この機能は EF Core 2.1 に追加される可能性があります。 🎜🎜🎜🎜🎜🎜🎜🎜🎜🎜🎜🎜以上がEF Core 2.0の新機能の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。