新聞中心
若要編寫ADO.NET出現(xiàn)錯誤處理程序中獲取更多此類錯誤信息,請使用相應(yīng)的語言或所在工作環(huán)境下的錯誤捕獲功能,然后使用嵌套的循環(huán)來枚舉 Errors 集合中每一個 Error 對象的屬性。

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括崇州網(wǎng)站建設(shè)、崇州網(wǎng)站制作、崇州網(wǎng)頁制作以及崇州網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,崇州網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到崇州省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
避免自動增量值沖突
就像大多數(shù)數(shù)據(jù)源一樣,編寫ADO.NET使您可標(biāo)識那些添加新行時自動對其值進(jìn)行遞增的列。在DataSet中使用自動增量的列時,如果自動增量的列來自數(shù)據(jù)源,可避免添加到DataSet的行和添加到數(shù)據(jù)源的行之間本地編號沖突。
例如,考慮一個表,它的主鍵列CustomerID是自動增量的。兩個新的客戶信息行添加到表中,并接收到自動增量的CustomerID值1和2。然后,只有第二個客戶行被傳遞給DataAdapter的方法Update,新添加的行在數(shù)據(jù)源接收到一個自動增量的CustomerID值1,與編寫ADO.NET中的值2不匹配。當(dāng)DataAdapter用返回值填充表中第二行時,就會出現(xiàn)約束沖突,因?yàn)?**個客戶行已經(jīng)使用了CustomerID值1。
要避免這種情況,建議在使用數(shù)據(jù)源上自動增量的列以及DataSet上自動增量的列時,將DataSet中的列創(chuàng)建為AutoIncrementStep值等于-1并且AutoIncrementSeed值等于0,另外,還要確保數(shù)據(jù)源生成的自動增量標(biāo)識值從1開始,并且以正階值遞增。因此,編寫ADO.NET為自動增量值生成負(fù)數(shù),與數(shù)據(jù)源生成的正自動增量值不沖突。另外一個選擇是使用GUID類型的列,而不是自動增量的列。生成GUID值的算法應(yīng)該永遠(yuǎn)不會使數(shù)據(jù)源中生成的GUID值與DataSet中生成的GUID值一樣。
如果自動增量的列只是用作唯一值,編寫ADO.NET而且沒有任何意義,就考慮使用GUID代替自動增量的列。它們是唯一的,并且避免了使用自動增量的列所必需的額外工作。
檢查開放式并發(fā)沖突
按照設(shè)計(jì),由于DataSet是與數(shù)據(jù)源斷開的,所以,當(dāng)多個客戶端在數(shù)據(jù)源上按照開放式并發(fā)模型更新數(shù)據(jù)時,需要確保應(yīng)用程序避免沖突。
在測試開放式并發(fā)沖突時有幾項(xiàng)技術(shù)。一項(xiàng)技術(shù)涉及在表中包含時間戳列。編寫ADO.NET另外一項(xiàng)技術(shù)是,驗(yàn)證一行中所有列的原始值是否仍然與通過在SQL語句中使用WHERE子句進(jìn)行測試時在數(shù)據(jù)庫中找到的值相匹配。 #t#
多線程編程
ADO.NET對性能、吞吐量和可伸縮性進(jìn)行優(yōu)化。因此,ADO.NET對象不鎖定資源,并且必須只用于單線程。一個例外是DataSet,它對多個閱讀器是線程安全的。但是,在寫的時候需要將DataSet鎖定。
僅在需要的時候才用COM Interop訪問ADO ADO.NET的設(shè)計(jì)目的是成為許多應(yīng)用程序的***解決方案。但是,有些應(yīng)用程序需要只有使用ADO對象才有的功能,例如,ADO多維(ADOMD)。在這些情況下,應(yīng)用程序可以用COM Interop訪問編寫ADO.NET。注意使用COM Interop訪問具有ADO的數(shù)據(jù)會導(dǎo)致性能降低。在設(shè)計(jì)應(yīng)用程序時,首先在實(shí)現(xiàn)用COM Interop訪問編寫ADO.NET的設(shè)計(jì)之前,先確定ADO.NET是否滿足設(shè)計(jì)需求。
當(dāng)前名稱:編寫ADO.NET時出現(xiàn)的錯誤提示
文章轉(zhuǎn)載:http://m.fisionsoft.com.cn/article/cdcoopo.html


咨詢
建站咨詢
