這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān).NET Core 3.0中System.Data的變化有什么,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)服務(wù)商,為中小企業(yè)提供做網(wǎng)站、成都網(wǎng)站制作服務(wù),網(wǎng)站設(shè)計,網(wǎng)站運營等一站式綜合服務(wù)型公司,專業(yè)打造企業(yè)形象網(wǎng)站,讓您在眾多競爭對手中脫穎而出創(chuàng)新互聯(lián)建站。
System.Data雖然不引人關(guān)注,但在.NET中,System.Data對于各種關(guān)系數(shù)據(jù)庫的連接是非常重要的。System.Data也被稱為ADO.NET,其前身是ActiveX Data Objects。System.Data提供了通過的框架,在她的基礎(chǔ)上.NET數(shù)據(jù)驅(qū)動應(yīng)用可以被構(gòu)建。這個框架還提供了數(shù)據(jù)驅(qū)動程序應(yīng)遵守的一些約定。
Connections,commands,data readers都是雙繼承。每個分別實現(xiàn)了來自于DbConnection, DbCommand,DbDataReader的基礎(chǔ)功能。他們也實現(xiàn)了抽象接口IDbConnection, IDbCommand, 和IDbDataReader,這使得它們能夠支持模擬場景和非傳統(tǒng)數(shù)據(jù)源。在下文描述的基礎(chǔ)類中都基于雙繼承方案。
雖然,connection strings一般被認(rèn)為是字符串,但有些工具卻認(rèn)為它是繼承自DbConnectionStringBuilder的對象。它能夠處理數(shù)據(jù)庫連接字符串的特定解析并幫助開發(fā)人員更好的理解特定數(shù)據(jù)庫的可用設(shè)置。
在.NET中System.Data早于ORM框架出現(xiàn),但是通過實現(xiàn)DbDataAdapter和DbCommandBuilder,它提供了生成sql的通用方法。它可以被直接使用,也能和普通數(shù)據(jù)集及類型化數(shù)據(jù)集組合使用。
如果你想找到一個抽象工廠模式的例子,你可以看下DbProviderFactory。它的自雷提供了connections, commands, command parameters, command builders, data adapters。其中包含了你需要的全部關(guān)于數(shù)據(jù)訪問的需求,而不僅僅是數(shù)據(jù)庫的邏輯。
接口的問題
在上文中已經(jīng)提到,System.Data依賴于雙繼承。當(dāng)我們想添加新的方法時,這將帶來問題。例如,異步操作被加入到在.NET 4.5的DbCommand之中。但是卻無法將他們添加到匹配的IDbCommand接口之中,因為這將是一個破壞性的改變。這意味著您不能同時使用異步操作和容易模擬的抽象接口。
微軟本可以在.NET Core 1.0中重新設(shè)計抽象接口,以使得其能夠與抽象類相匹配(Java通過JDBC的接口已經(jīng)實現(xiàn)了)。然而,這卻會使得.NET Framework共用源碼變得困難。
如果默認(rèn)接口方法能夠出現(xiàn)在C#8.0中,在理論上,這一特征可以用來以向后兼容的方式調(diào)整接口。但是在.NET Framework中并不兼容,因為默認(rèn)接口方法只是.NET Core的特征。它也不能使用較老的編譯器和其他.NET語言。
DbDataReader.Get()中的字符串重載
我們對于System.Data在.NET Core 3.0之中的第一個特征是DbDataReader的Get()方法之中能夠傳遞列名。長期以來,人們一直抱怨這個接口不能按名稱引用列。這意味著你需要使用這個模式 。
1 | reader.GetInt32(reader.GetOrdinal(
"columnName"
))
|
一個明顯的(對某些人來說,也是早就應(yīng)該有的)簡化方法是提供字符串重載。
1 | reader.GetInt32(
"columnName"
)
|
這已經(jīng)在Oracle's Connector/NET和MySQLConnector中實現(xiàn)。
處于性能考慮,該方法不會被標(biāo)記為虛方法,從而允許JIT編譯器輕松地內(nèi)聯(lián)它。也是由于上述原因,新的方法集不會添加到IDbDataReader中。
XmlDataDocument
如果你了解XmlDataDocument的歷史,這似乎是一個奇怪的選擇。在2010年發(fā)布的.NET 4.0之中,其已經(jīng)被標(biāo)記為過時的,并提出了XmlDataDocument在未來的版本中將會被刪除的警告?,F(xiàn)在使用它的原因是一些WinForms和WPF應(yīng)用程序使用它,在bug報告中稱,其在Apiport的各種類別中有1-7%的使用率。
DatasetExtensions
DataTableExtensions在.NET Core 3之中將不再支持。雖然它看起來只是有6個擴展方法的類,但是在不修改System.Data的情況下,我們無法構(gòu)建AsDataView方法。原因相當(dāng)?shù)膹?fù)雜,涉及內(nèi)部方法、類型轉(zhuǎn)發(fā)和.NET Standard帶來的挑戰(zhàn)。
上述就是小編為大家分享的.NET Core 3.0中System.Data的變化有什么了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。