本篇內(nèi)容介紹了“ADO.NET 批處理更新步驟是什么”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),競秀企業(yè)網(wǎng)站建設(shè),競秀品牌網(wǎng)站建設(shè),網(wǎng)站定制,競秀網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,競秀網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
在ADO.NET 批處理中,批處理更新只可能發(fā)生在基于 SQL 的數(shù)據(jù)源上。在ADO.NET 批處理中,批處理更新則可能發(fā)生在任何種類的托管提供程序上,其中包括那些不應(yīng)該通過 SQL 查詢語言公開其數(shù)據(jù)的托管提供程序。
在這兩種情況下,數(shù)據(jù)訪問都會產(chǎn)生完全雙向綁定,并涉及各種不同的對象和方法。您可以使用如 SqlCommand 和 OleDbCommand 等命令類來執(zhí)行單個命令??墒褂脭?shù)據(jù)適配器對象來下載斷開連接的數(shù)據(jù),提交更新的行集。雖然 “數(shù)據(jù)集” 是數(shù)據(jù)適配器用于返回和提交記錄塊的容器對象,但各個命令通過數(shù)據(jù)讀取器對象返回數(shù)據(jù)。
更新是通過各個命令、存儲過程完成的,通常,ADO.NET 批處理托管提供程序理解的任何命令文本一般都被稱為更新。更新命令總是執(zhí)行嵌入在語句正文中的新數(shù)據(jù)。更新命令總是需要一個打開的連接,可能還需要一個正在進行的事務(wù)處理或一個新的事務(wù)處理。
批處理更新則是一個略有不同的方法分支。從***的抽象級別來看,您并不發(fā)出命令,無論它可能有多么復(fù)雜。取而代之的是,您提交在客戶端修改的當(dāng)前行的快照,并等待數(shù)據(jù)源批準。批處理更新背后的關(guān)鍵概念是數(shù)據(jù)斷開連接的概念。您下載行表,通常為數(shù)據(jù)集,根據(jù)需要在客戶端對它進行修改,然后將這些行的新映像提交到數(shù)據(jù)庫服務(wù)器。您所作的是提交更改,而不是執(zhí)行一個對數(shù)據(jù)源創(chuàng)建更改的命令。這就是更新(我在 July column 一文中討論過這個問題)和批處理更新之間的本質(zhì)區(qū)別。
下圖說明了ADO.NET 應(yīng)用程序的雙更新體系結(jié)構(gòu)。
在進一步詳細討論 ADO.NET 批處理更新之前,我需要闡明常常會導(dǎo)致某種誤解的批處理更新模型的一個方面。雖然更新和批處理更新在 ADO.NET 內(nèi)的實際實現(xiàn)方面有著本質(zhì)的區(qū)別,但它們遵循的是同一個更新模型。更新和批處理更新都是通過直接的并且特定于提供程序的語句來完成的。
當(dāng)然,由于批處理更新通常涉及到更多的行,所以這些語句會被組合為一個批處理調(diào)用。批處理更新會對目標(biāo)數(shù)據(jù)集的行進行從頭到尾的循環(huán),只要發(fā)現(xiàn)更新的行,就會發(fā)出適當(dāng)?shù)母旅睿↖NSERT、DELETE 或 UPDATE)。對更新的行進行通信時,ADO.NET 批處理將運行一個預(yù)定義的直接 SQL 命令。從本質(zhì)上來說,這就是批處理更新。
“ADO.NET 批處理更新步驟是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!