1. 程式人生 > >[翻譯]EntityFramework Core 2.2 釋出

[翻譯]EntityFramework Core 2.2 釋出

原文來源 TechViews


今天我們將推出EF Core 2.2的最終版本,以及ASP.NET Core 2.2.NET Core 2.2 。這是我們的開源和跨平臺物件資料庫對映技術的最新版本。

EF Core 2.2 RTM包含一百多個錯誤修復和一些新功能:

空間資料支援

空間資料可用於表示物件的物理位置和形狀。許多資料庫可以本地儲存,索引和查詢空間資料。常見方案包括查詢給定距離內的物件,以及測試多邊形是否包含給定位置。 EF Core 2.2現在支援使用NetTopologySuite (NTS)庫中的型別處理來自各種資料庫的空間資料。

空間資料支援是作為一系列特定於提供者的擴充套件包實現的。這些包中的每一個都為NTS型別和方法以及資料庫中相應的空間型別和功能提供對映。此類提供程式擴充套件現在可用於

SQL ServerSQLitePostgreSQL (來自Npgsql專案 )。空間型別可以直接與EF Core記憶體提供程式一起使用,無需額外擴充套件。

安裝提供程式擴充套件後,可以向實體新增支援的型別的屬性。例如:

 using NetTopologySuite.Geometries;

namespace MyApp
{
public class Friend
{
[Key]
public string Name { get; set; }

[Required]
public Point Location { get; set; }

}
}

然後,您可以使用空間資料保留實體:

 using (var context = new MyDbContext())
{
context.Add(
new Friend
{
Name = "Bill",
Location = new Point(-122.34877, 47.6233355) {SRID = 4326 }
});
context.SaveChanges();
}

您可以根據空間資料和操作執行資料庫查詢:

  var nearestFriends =
(from f in context.Friends
orderby f.Location.Distance(myLocation) descending
select f).Take(5).ToList();

有關此功能的更多資訊,請參閱空間資料文件

擁有實體的集合

EF Core 2.0增加了在一對一關聯中建立所有權模型的能力。 EF Core 2.2擴充套件了將所有權表達為一對多關聯的能力。所有權有助於限制實體的使用方式。

例如,擁有的實體: - 只能出現在其他實體型別的導航屬性上。 - 自動載入,並且只能由DbContext與其所有者一起跟蹤。

在關係資料庫中,擁有的集合對映到所有者的單獨表,就像常規的一對多關聯一樣。但是在面向文件的資料庫中,我們計劃將擁有的實體(在擁有的集合或引用中)巢狀在與所有者相同的文件中。

您可以通過呼叫新的OwnsMany()API來使用該功能:

 modelBuilder.Entity<Customer>().OwnsMany(c => c.Addresses); 

有關更多資訊,請參閱更新的自有實體文件

查詢標籤

此功能簡化了程式碼中的LINQ查詢與日誌中捕獲的生成的SQL查詢的關聯。

要利用查詢標記,請使用新的TagWith()方法註釋LINQ查詢。使用前一個示例中的空間查詢:

  var nearestFriends =
(from f in context.Friends.TagWith(@"This is my spatial query!")
orderby f.Location.Distance(myLocation) descending
select f).Take(5).ToList();

此LINQ查詢將生成以下SQL輸出:

 -- This is my spatial query!

SELECT TOP(@__p_1) [f].[Name], [f].[Location]
FROM [Friends] AS [f]
ORDER BY [f].[Location].STDistance(@__myLocation_0) DESC

有關更多資訊,請參閱查詢標記文件

獲得EF Core 2.2

EF Core NuGet包可以在NuGet Gallery上獲得 ,也可以作為ASP.NET Core 2.2新的.NET Core SDK的一部分

如果要在基於ASP.NET Core的應用程式中使用EF Core,我們建議您首先將應用程序升級到ASP.NET Core 2.2

通常,在應用程式中使用EF Core的最佳方法是為應用程式將使用的提供程式安裝相應的NuGet包。例如,要從命令列在.NET Core專案中新增2.2版本的SQL Server提供程式,請使用:

 $ dotnet add package Microsoft.EntityFrameworkCore.SqlServer -v 2.2.0 

或者從Visual Studio中的程式包管理器控制檯:

 PM> Install-Package Microsoft.EntityFrameworkCore.SqlServer -Version 2.2.0 

有關如何將EF Core新增到專案的更多資訊,請參閱有關安裝Entity Framework Core的文件

與EF Core 2.1的相容性

我們花了很多時間和精力確保EF Core 2.2向後相容現有的EF Core 2.1提供程式,並且更新應用程式以在EF Core 2.2上構建不會導致相容性問題。我們預計大多數升級都會順利進行,但如果您發現任何意外問題,請向我們的問題跟蹤器報告。

EF Core 2.2中存在一個已知的更改,可能需要在應用程式程式碼中進行少量更新。有關更多詳細資訊,請閱讀以下問題的說明:

  • #13986配置為擁有實體和常規實體的型別需要在從2.1升級到2.2後定義主鍵

我們打算維護一份可能需要調整問題跟蹤器上現有程式碼的問題列表。

接下來是什麼:EF Core 3.0

隨著EF Core 2.2的出現,我們的主要關注點是EF Core 3.0。我們仍需要弄清楚下一個主要版本的幾個細節,但這裡是我們目前所知的一些主要主題:

  • LINQ改進 :LINQ使您能夠在不離開您選擇的語言的情況下編寫資料庫查詢,利用豐富的型別資訊來獲取IntelliSense和編譯時型別檢查。但LINQ還使您能夠編寫無限數量的複雜查詢,這對LINQ提供商來說一直是一個巨大的挑戰。在EF Core的前幾個版本中,我們通過弄清楚查詢的哪些部分可以轉換為SQL,然後允許其餘查詢在客戶端的記憶體中執行來解決。在某些情況下,此客戶端執行可能是合乎需要的,但在許多其他情況下,它可能導致在將應用程式部署到生產之前可能無法識別的低效查詢。在EF Core 3.0中,我們計劃對LINQ實現的工作方式以及測試方式進行深刻的更改。目標是使其更加健壯(例如,避免破壞補丁版本中的查詢),能夠將更多表達式正確地轉換為SQL,在更多情況下生成有效查詢,並防止低效查詢未被檢測到。
  • Cosmos DB支援 :我們正在為EF Core開發Cosmos DB提供程式,使熟悉EF程式設計模型的開發人員能夠輕鬆地將Azure Cosmos DB作為應用程式資料庫。目標是利用Cosmos DB的一些優勢,如全域性分發,“始終線上”可用性,彈性可伸縮性和低延遲,.NET開發人員更容易訪問。提供程式將針對Cosmos DB中的SQL API啟用大多數EF Core功能,如自動更改跟蹤,LINQ和值轉換。我們在EF Core 2.2之前就開始了這項工作, 我們已經提供了一些提供商的預覽版本 。新計劃是繼續與EF Core 3.0一起開發提供商。
  • C#8.0支援 :我們希望我們的客戶能夠利用C#8.0中的一些新功能,例如非同步流(包括等待每個)和使用EF Core時可以為空的引用型別。
  • 將資料庫檢視反轉為查詢型別:在EF Core 2.1中,我們添加了對查詢型別的支援,查詢型別可以表示可以從資料庫讀取但無法更新的資料。查詢型別非常適合對映資料庫檢視,因此在EF Core 3.0中,我們希望自動建立資料庫檢視的查詢型別。
  • 屬性包實體 :此功能是關於啟用在索引屬性中儲存資料而不是常規屬性的實體,以及是否能夠使用相同.NET類的例項(可能像Dictionary<string, object>這樣簡單的例項)表示同一EF Core模型中的不同實體型別。此功能是支援多對多關係的墊腳石,沒有連線實體,這是EF Core最需要的改進之一。
  • .NET Core上的EF 6.3 :我們知道許多現有應用程式使用以前版本的EF,並且將它們移植到EF Core只是為了利用.NET Core有時需要付出巨大努力。出於這個原因,我們將調整下一版本的EF 6以在.NET Core 3.0上執行。我們這樣做是為了便於以最小的更改移植現有的應用程式。會有一些限制(例如,它將需要新的提供程式,不會啟用SQL Server的空間支援),並且沒有為EF 6計劃的新功能。

謝謝

EF團隊感謝大家對EF Core 2.2的所有社群反饋和貢獻。再一次,您可以報告在我們的問題跟蹤器中找到的任何新問題。