自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

編寫(xiě)ADO.NET時(shí)出現(xiàn)的錯(cuò)誤提示

開(kāi)發(fā) 后端
對(duì)于編寫(xiě)ADO.NET時(shí)會(huì)出現(xiàn)各種各樣的問(wèn)題,下面是一些技術(shù)人員編寫(xiě)ADO.NET代碼時(shí)的通用技巧,歡迎大家進(jìn)行學(xué)習(xí)參考。

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

避免自動(dòng)增量值沖突

就像大多數(shù)數(shù)據(jù)源一樣,編寫(xiě)ADO.NET使您可標(biāo)識(shí)那些添加新行時(shí)自動(dòng)對(duì)其值進(jìn)行遞增的列。在DataSet中使用自動(dòng)增量的列時(shí),如果自動(dòng)增量的列來(lái)自數(shù)據(jù)源,可避免添加到DataSet的行和添加到數(shù)據(jù)源的行之間本地編號(hào)沖突。

例如,考慮一個(gè)表,它的主鍵列CustomerID是自動(dòng)增量的。兩個(gè)新的客戶信息行添加到表中,并接收到自動(dòng)增量的CustomerID值1和2。然后,只有第二個(gè)客戶行被傳遞給DataAdapter的方法Update,新添加的行在數(shù)據(jù)源接收到一個(gè)自動(dòng)增量的CustomerID值1,與編寫(xiě)ADO.NET中的值2不匹配。當(dāng)DataAdapter用返回值填充表中第二行時(shí),就會(huì)出現(xiàn)約束沖突,因?yàn)?**個(gè)客戶行已經(jīng)使用了CustomerID值1。

要避免這種情況,建議在使用數(shù)據(jù)源上自動(dòng)增量的列以及DataSet上自動(dòng)增量的列時(shí),將DataSet中的列創(chuàng)建為AutoIncrementStep值等于-1并且AutoIncrementSeed值等于0,另外,還要確保數(shù)據(jù)源生成的自動(dòng)增量標(biāo)識(shí)值從1開(kāi)始,并且以正階值遞增。因此,編寫(xiě)ADO.NET為自動(dòng)增量值生成負(fù)數(shù),與數(shù)據(jù)源生成的正自動(dòng)增量值不沖突。另外一個(gè)選擇是使用GUID類型的列,而不是自動(dòng)增量的列。生成GUID值的算法應(yīng)該永遠(yuǎn)不會(huì)使數(shù)據(jù)源中生成的GUID值與DataSet中生成的GUID值一樣。

如果自動(dòng)增量的列只是用作唯一值,編寫(xiě)ADO.NET而且沒(méi)有任何意義,就考慮使用GUID代替自動(dòng)增量的列。它們是唯一的,并且避免了使用自動(dòng)增量的列所必需的額外工作。

檢查開(kāi)放式并發(fā)沖突

按照設(shè)計(jì),由于DataSet是與數(shù)據(jù)源斷開(kāi)的,所以,當(dāng)多個(gè)客戶端在數(shù)據(jù)源上按照開(kāi)放式并發(fā)模型更新數(shù)據(jù)時(shí),需要確保應(yīng)用程序避免沖突。

在測(cè)試開(kāi)放式并發(fā)沖突時(shí)有幾項(xiàng)技術(shù)。一項(xiàng)技術(shù)涉及在表中包含時(shí)間戳列。編寫(xiě)ADO.NET另外一項(xiàng)技術(shù)是,驗(yàn)證一行中所有列的原始值是否仍然與通過(guò)在SQL語(yǔ)句中使用WHERE子句進(jìn)行測(cè)試時(shí)在數(shù)據(jù)庫(kù)中找到的值相匹配。 #t#

多線程編程

ADO.NET對(duì)性能、吞吐量和可伸縮性進(jìn)行優(yōu)化。因此,ADO.NET對(duì)象不鎖定資源,并且必須只用于單線程。一個(gè)例外是DataSet,它對(duì)多個(gè)閱讀器是線程安全的。但是,在寫(xiě)的時(shí)候需要將DataSet鎖定。

僅在需要的時(shí)候才用COM Interop訪問(wèn)ADO ADO.NET的設(shè)計(jì)目的是成為許多應(yīng)用程序的***解決方案。但是,有些應(yīng)用程序需要只有使用ADO對(duì)象才有的功能,例如,ADO多維(ADOMD)。在這些情況下,應(yīng)用程序可以用COM Interop訪問(wèn)編寫(xiě)ADO.NET。注意使用COM Interop訪問(wèn)具有ADO的數(shù)據(jù)會(huì)導(dǎo)致性能降低。在設(shè)計(jì)應(yīng)用程序時(shí),首先在實(shí)現(xiàn)用COM Interop訪問(wèn)編寫(xiě)ADO.NET的設(shè)計(jì)之前,先確定ADO.NET是否滿足設(shè)計(jì)需求。

責(zé)任編輯:chenqingxiang 來(lái)源: 博客園
相關(guān)推薦

2009-12-29 15:38:05

ADO.NET語(yǔ)句

2011-05-20 11:31:07

ADO.NET

2009-12-22 14:52:54

ADO.NET腳本

2009-12-23 16:05:47

ADO.NET錯(cuò)誤

2009-12-28 15:11:36

ADO.NET專家

2009-12-29 13:40:24

使用ADO.NET

2011-06-02 09:39:29

ADO.NET

2009-11-03 16:37:10

2009-09-14 13:37:25

LINQ ADO.NE

2010-01-04 10:48:30

ADO.NET特色

2009-07-06 10:43:51

ADO.NET

2009-11-03 17:25:59

ADO.NET編程技巧

2009-11-12 14:37:26

ADO.NET結(jié)構(gòu)

2009-10-29 13:34:01

ADO.NET對(duì)象

2009-11-12 10:32:47

ADO.NET技術(shù)

2009-11-12 13:26:56

使用ADO.NET參數(shù)

2009-12-24 14:49:38

ADO.NET運(yùn)行錯(cuò)誤

2009-12-18 14:37:56

ADO.NET模型

2009-11-12 13:53:27

ADO.NET Sel

2009-11-12 09:51:59

ADO.NET結(jié)構(gòu)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)