空值處理二講述_第1頁(yè)
空值處理二講述_第2頁(yè)
空值處理二講述_第3頁(yè)
空值處理二講述_第4頁(yè)
空值處理二講述_第5頁(yè)
已閱讀5頁(yè),還剩5頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、空值處理 二 1.空值處理 數(shù)據(jù)庫(kù)中 沒(méi)有C#中的null 值 下面的判斷空值的方法就是錯(cuò)誤的DataRow dr =TableName.Rows0 ; if(dr"ID"=null) / 這是錯(cuò)誤的 它不能判斷是否為空值。return;在數(shù)據(jù)庫(kù)中 空值是DBNULL 判斷方法應(yīng)該是if(dr"id"=DBnull.value)return;或者這樣判斷if(dr"id".tostring()=string.empty)return;這里有產(chǎn)生了一個(gè)問(wèn)題 什么樣的數(shù)據(jù)可以轉(zhuǎn)化為字符串 保

2、證這個(gè)轉(zhuǎn)化不報(bào)錯(cuò)object aa=null; string Eorr= aa.toString(); /這個(gè)會(huì)報(bào)錯(cuò)誤 提示數(shù)據(jù)沒(méi)有實(shí)例化 也就是這種空值不能轉(zhuǎn)化成字符串 object bb=DBnull.value; string Right=bb.toString(); /這個(gè)是正確的 它轉(zhuǎn)化出來(lái)的是 空字符串" ".if(Right=string.Empty) 這會(huì)是正確的 他們相等 同時(shí) 有 " "=string.Empty=Right;.在數(shù)據(jù)庫(kù) 使用 select * from TableName 這樣的語(yǔ)句查

3、詢時(shí) 經(jīng)常查到某個(gè)字段的值是NULL,也有為空白的。它們有什么區(qū)別呢 ??瞻拙褪强罩?空值也是一中值 相當(dāng)于空字符串“ ” 在C# 里把它轉(zhuǎn)化為字符串時(shí) 它的確也就是空字符串在數(shù)據(jù)庫(kù)中看到的NULL 其實(shí)是表示數(shù)據(jù)值不確定 未知 對(duì)于剛剛?cè)腴T(mén)的我就直接把它當(dāng)作空值使用。在C#中 它就對(duì)應(yīng)DBnull.value , 我猜測(cè)DBnull.value 它也就是為了處理數(shù)據(jù)庫(kù)的數(shù)據(jù)方便而特意設(shè)計(jì)的一種數(shù)據(jù)值。剛才看了,DBNull.value 轉(zhuǎn)化為字符串是也空字符串“ ”。所以在數(shù)據(jù)庫(kù)中要判斷一個(gè)數(shù)據(jù)是否為空 最保險(xiǎn)的方法就是if(dr"id".tostring

4、()=string.Empty) / 它不會(huì)有報(bào)錯(cuò)發(fā)生 因?yàn)閿?shù)據(jù)庫(kù)中沒(méi)有C# 對(duì)象為null的現(xiàn)象。. /如果你是自己賦值了的話就難以肯定的說(shuō)了 只能說(shuō)從數(shù)據(jù)庫(kù)中獲取的數(shù)據(jù)沒(méi)有 對(duì)象沒(méi)有實(shí)例化的null現(xiàn)象.2.常量值造成的影響例如 寫(xiě)一個(gè)不同的付款方式 折扣不同的函數(shù)float GetDiscountRate(string PayWayName)if(DisCounWayName ="銀行卡")/五折if(DisCounWayName ="現(xiàn)金")/7折 這個(gè)函數(shù)中使用了兩個(gè)常量值 "現(xiàn)金&qu

5、ot; , "銀行卡" 它產(chǎn)生了什么影響呢 別人在使用這個(gè)函數(shù)時(shí)就一定要知道這個(gè)函數(shù)傳遞什么參數(shù)才有效果 如果別人傳遞參數(shù)名為“存值卡” 時(shí)就毫無(wú)作用 也就是說(shuō)函數(shù)參數(shù)的值是有限定的 這個(gè)函數(shù)在使用時(shí)就要求別人首先一定要知道內(nèi)部支持實(shí)現(xiàn)了哪些付款方式。 這就是一種高耦合 改善后的寫(xiě)法應(yīng)該是 float GetDiscountRate(bool PayWay) if(PayWay )/ 銀行卡 五折else/存值卡 7折 上面的寫(xiě)法就是把參數(shù)類型變成BOOL限制成只有兩種情況 了 用 true 代表銀行卡 false 代表現(xiàn)金 那么別人在使用這個(gè)函數(shù)時(shí)就一定不

6、會(huì)用錯(cuò)了如果是更多的情況就可以使用枚舉類型 枚舉類型 可以支持很好的擴(kuò)展型 使用它最佳 。再說(shuō) dr"銀行卡" 假設(shè)它表示在數(shù)據(jù)庫(kù)中用銀行卡支付的付款額 dr"銀行卡" 這個(gè) 直接用“銀行卡”這個(gè)常量值寫(xiě)法 產(chǎn)生的是什么問(wèn)題呢產(chǎn)生的問(wèn)題是 如果數(shù)據(jù)庫(kù)字段名稱變更 它就會(huì)報(bào)錯(cuò) 軟件崩潰 。如果是大面積使用的這個(gè)寫(xiě)法 就會(huì)大面積錯(cuò)誤 例如后來(lái)發(fā)現(xiàn) 銀行卡這個(gè)字段名 不準(zhǔn)確 應(yīng)該叫 銀聯(lián)卡 更加準(zhǔn)確。那么改起來(lái)就會(huì)很痛苦 Ctrl+F 或許可以很快替換名稱但是這也是危險(xiǎn)的。有常量值造成的其實(shí)是一種人必須了解編程細(xì)節(jié)的麻煩。 在多

7、個(gè)函數(shù)中使用同一個(gè)常量值 還會(huì)造成多個(gè)函數(shù)的強(qiáng)聯(lián)系。舉例就不舉了 我曾經(jīng)遇到過(guò) 是很痛苦的經(jīng)歷。3說(shuō)一下寫(xiě)程序的一些簡(jiǎn)單原則少用常量 例如 整數(shù)值突然冒出一個(gè) if(a=7)。 這個(gè)自己哪一天再看也會(huì)忘記為什么這里要用7 判斷 最后保證每個(gè)函數(shù)是獨(dú)立關(guān)系 。在開(kāi)發(fā)企業(yè)管理軟件時(shí) 很常見(jiàn)的情況是寫(xiě)一個(gè)函數(shù)必然有數(shù)據(jù)驗(yàn)證的部分 我覺(jué)得最后不要把數(shù)據(jù)驗(yàn)證部分交給其他函數(shù)來(lái)驗(yàn)證。很多時(shí)候 利用邏輯上的關(guān)系 一個(gè)函數(shù)是可以免去數(shù)據(jù)驗(yàn)證的 但是數(shù)據(jù)庫(kù)的隨機(jī)事故發(fā)生時(shí) 你那個(gè)函數(shù)可能就無(wú)非工作了。例如 保存進(jìn)入數(shù)據(jù)庫(kù)時(shí) 假設(shè)要分別保存 進(jìn)不同的表 一個(gè)是主表 一個(gè)是明細(xì)表 為了偷懶我們很可能的做法是在保存主

8、表的函數(shù)里面進(jìn)行了數(shù)據(jù)驗(yàn)證 所以在保存明細(xì)表示就不驗(yàn)證數(shù)據(jù)是否有效了。這造成的影響是:你一開(kāi)始寫(xiě)這個(gè)保存明細(xì)的代碼時(shí) 你利用邏輯上先保存主表在保存明細(xì)表這個(gè)邏輯順序免去了寫(xiě)數(shù)據(jù)驗(yàn)證的代碼 但是在你在其它地方想使用這個(gè)函數(shù)時(shí) 就沒(méi)有了這個(gè)邏輯順序可以利用了 你再貿(mào)然使用這個(gè)函數(shù)就會(huì)特別危險(xiǎn) 所以寫(xiě)函數(shù)時(shí)就不能依靠事物邏輯下形成的便利。函數(shù)抵抗隨機(jī)性的能力會(huì)變差 有可能程序恰好運(yùn)行到這個(gè)函數(shù) 而有人已經(jīng)把在后臺(tái)把數(shù)據(jù)庫(kù)給修改了。這個(gè)時(shí)候就很可能發(fā)生錯(cuò)誤 使軟件崩潰。生活中使用電腦常見(jiàn)的錯(cuò)誤就是由文件丟失導(dǎo)致軟件崩潰。錯(cuò)誤就有可能是在其它函數(shù)中檢查了這個(gè)文件是否存在 而然在另外某個(gè)函數(shù)沒(méi)有檢查文件是

9、否存在 因?yàn)榫幊倘藛T一開(kāi)始是在有事件邏輯關(guān)系下 寫(xiě)的代碼 。所以寫(xiě)一個(gè)函數(shù)就應(yīng)該有自己獨(dú)立的數(shù)據(jù)驗(yàn)證部分。提高處理隨機(jī)問(wèn)題的能力。寫(xiě)代碼時(shí) 一定要考慮第二次使用時(shí) 或者別人使用時(shí)會(huì)發(fā)生什么例如 這樣一個(gè)更新數(shù)據(jù)庫(kù)的函數(shù)int UpdatePos(Pos pos) / 更新消費(fèi)記錄表 Pos 表示那張消費(fèi)記錄表List<Field >list=new List<Field>();/ Field 表示一個(gè)表的字段實(shí)體 包括字段名 字段值for(string fieldName in pos.FieldNames) list.add(posfi

10、eldName); /這里是為了配置滿足下面那個(gè)更新函數(shù)的參數(shù) Field return SqlHelp.UpdatePos(list.toArry(),pos.flowNo);/利用流水號(hào)更新消費(fèi)記錄這個(gè)函數(shù)有什么問(wèn)題呢 一開(kāi)始我就是這樣寫(xiě)的 當(dāng)時(shí)是沒(méi)有空值的情況發(fā)生的 但以后 用著就發(fā)現(xiàn)問(wèn)題了 如果某個(gè)字段值為Null ,程序就報(bào)錯(cuò) 。于是我又改成了 int UpdatePos(Pos pos) /更新消費(fèi)記錄表 Pos 表示那張消費(fèi)記錄表List<Field >list=new List<Field>();/ Field 表示一個(gè)表的字段實(shí)體 包括字段名 字段值for(string fieldName in pos.FieldNames) if(posfieldName=null) /我實(shí)現(xiàn)了表pos 由字段名稱索引continue; list.add(posfieldName); /這里是為

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論