您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關.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()方法之中能夠傳遞列名。長期以來,人們一直抱怨這個接口不能按名稱引用列。這意味著你需要使用這個模式 。
1 | reader.GetInt32(reader.GetOrdinal(
"columnName"
))
|
一個明顯的(對某些人來說,也是早就應該有的)簡化方法是提供字符串重載。
1 | 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帶來的挑戰。
上述就是小編為大家分享的.NET Core 3.0中System.Data的變化有什么了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。