.NET Core 3.0:System.Data的變化


System.Data雖然不引人關注,但在.NET中,System.Data對於各種關系數據庫的連接是非常重要的。System.Data也被成為ADO.NET,其前身是ActiveX Data Objects。System.Data提供了通過的框架,在她的基礎上.NET數據驅動應用可以被構建。這個框架還提供了數據驅動程序應遵守的一些約定。

Connections,commands,data readers都是雙繼承。每個分別實現了來自於DbConnection, DbCommand,DbDataReader的基礎功能。他們也實現了抽象接口IDbConnection, IDbCommand, 和IDbDataReader,這使得它們能夠支持模擬場景和非傳統數據源。在下文描述的基礎類中都基於雙繼承方案。

雖然,connection strings一般被認為是字符串,但有些工具卻認為它是繼承自DbConnectionStringBuilder的對象。它能夠處理數據庫連接字符串的特定解析並幫助開發人員更好的理解特定數據庫的可用設置。

在.NET中System.Data早於ORM框架出現,但是通過實現DbDataAdapter和DbCommandBuilder,它提供了生成sql的通用方法。它可以被直接使用,也能和普通數據集及類型化數據集組合使用。

如果你想找到一個抽象工廠模式的例子,你可以看下DbProviderFactory。它的自雷提供了connections, commands, command parameters, command builders, data adapters。其中包含了你需要的全部關於數據訪問的需求,而不僅僅是數據庫的邏輯。

接口的問題

在上文中已經提到,System.Data依賴於雙繼承。當我們想添加新的方法時,這將帶來問題。例如,異步操作被加入到在.NET 4.5的DbCommand之中。但是卻無法將他們添加到匹配的IDbCommand接口之中,因為這將是一個破壞性的改變。這意味着您不能同時使用異步操作和容易模擬的抽象接口。

微軟本可以在.NET Core 1.0中重新設計抽象接口,以使得其能夠與抽象類相匹配(Java通過JDBC的接口已經實現了)。然而,這卻會使得.NET Framework共用源碼變得困難。

如果默認接口方法能夠出現在C#8.0中,在理論上,這一特征可以用來以向后兼容的方式調整接口。但是在.NET Framework中並不兼容,因為默認接口方法只是.NET Core的特征。它也不能使用較老的編譯器和其他.NET語言

DbDataReader.Get()中的字符串重載

我們對於System.Data在.NET Core 3.0之中的第一個特征是DbDataReader的Get()方法之中能夠傳遞列名。長期以來,人們一直抱怨這個接口不能按名稱引用列。這意味着你需要使用這個模式 。

reader.GetInt32(reader.GetOrdinal("columnName"))

一個明顯的(對某些人來說,也是早就應該有的)簡化方法是提供字符串重載。

reader.GetInt32("columnName")

這已經在Oracle's Connector/NET和MySqlConnector中實現。

處於性能考慮,該方法不會被標記為虛方法,從而允許JIT編譯器輕松地內聯它。也是由於上述原因,新的方法集不會添加到IDbDataReader中。

XmlDataDocument

如果你了解XmlDataDocument的歷史,這似乎是一個奇怪的選擇。在2010年發布的.NET 4.0之中,其已經被標記為過時的,並提出了XmlDataDocument在未來的版本中將會被刪除的警告。現在使用它的原因是一些WinForms和WPF應用程序使用它,在bug報告中稱,其在Apiport的各種類別中有1-7%的使用率。

DatasetExtensions

DataTableExtensions在.NET Core 3之中將不在支持。雖然它看起來只是有6個擴展方法的類,但是在不修改System.Data的情況下,我們無法構建AsDataView方法。原因相當的復雜,涉及內部方法、類型轉發和.NET Standard帶來的挑戰。

如果你感興趣,可以與我們聯系鏈接2)。

本文翻譯自System.Data in .NET Core 3.0


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM