Null,DBNULL等的區別?

2021-05-23 02:44:04 字數 3321 閱讀 3970

1.對dbnull的解釋:

該類用於指示不存在某個已知值(通常在資料庫應用程式中)。

在資料庫應用程式中,空物件是字段的有效值。該類區分空值(空物件)和未初始化值(dbnull.value例項)。例如,表可以包含具有未初始化欄位的記錄。預設情況下,這些未初始化字段具有dbnull值。

該類還可以用於在com interop中區分 vt_null 變數(與空物件關聯)和 vt_empty  變數(與dbnull.value例項關聯)。

dbnull   從不等於任何值。

dbnull   是乙個單獨的類,這意味著該類只能存在乙個例項。這個唯一的例項是   dbnull.value。

訪問   sql   資料庫的資料密集應用程式必須使用   system.data.sqltypes   類,這些類對空值具有內在支援。

dbnull在dotnet是單獨的乙個型別,該類只能存在唯一的例項,dbnull.value,dbnull唯一作用是可以表示資料庫中的字串,數 字,或日期,為什麼可以表示原因是dotnet儲存這些資料的類(datarow等)都是以 object 的形式來儲存資料的。對於 datarow , 它的 row[column] 返回的值永遠不為 null , 要麼就是具體的為column 的型別的值 。 要麼就是 dbnull 。 所以 row[column].tostring() 這個寫法永遠不會在tostring那裡發生nullreferenceexception。dbnull 實現了 iconvertible 。但是,除了 tostring 是正常的外,其他的to***都會丟擲不能轉換的錯誤。

2. null

null 關鍵字是表示不引用任何物件的空引用的文字值。null 是引用型別變數的預設值。那麼也只有引用型的變數可以為null,如果 int i=null,的話,是不可以的,因為int是值型別的。

"null" means the object reference is invalid in .net, when you  retrieve   a   null   value   from   the   database,   it   is   a   valid   value   to   .net,   and   it   is   represented   by   system.dbnull.value

null用於判斷reference   invalidate

3.""和string.empty

這兩個都是表示空字串,其中有乙個重點是string str1="" 和 string str2=null 的區別,這樣定義後,str1是乙個空字串,空字串是乙個特殊的字串,只不過這個字串的值為空,在記憶體中是有準確的指向的,string str2=null,這樣定義後,只是定義了乙個string 類的引用,str2並沒有指向任何地方,在使用前如果不例項化的話,都將報錯。

4.convert.isdbnull()

convert.isdbnull()返回有關指定物件是否為 dbnull 型別的指示,即是用來判斷物件是否為dbnull的。其返回值是true或flase。

dbnull在dotnet是單獨的乙個型別 system.dbnull 。它只有乙個值 dbnull.value 。dbnull 直接繼承 object ,所以 dbnull 不是 string , 不是 int , 也不是 datetime 。。。

但是為什麼 dbnull 可以表示資料庫中的字串,數字,或日期呢?原因是dotnet儲存這些資料的類(datarow等)都是以 object 的形式來儲存資料的。

對於 datarow , 它的 row[column] 返回的值永遠不為 null , 要麼就是具體的為column 的型別的值。要麼就是 dbnull 。 所以 row[column].tostring() 這個寫法永遠不會在tostring那裡發生nullreferenceexception。

dbnull 實現了 iconvertible 。 但是,除了 tostring 是正常的外,其他的to***都會丟擲不能轉換的錯誤。

在 idbcommand(oledbcommand,sqlcommand...) 的executescalar的返回值中,情況可以這樣分析:

select 1 這樣返回的object是 1

select null 這樣返回的是dbnull.value

select isnull(null,1) 返回的是 1

select top 0 id from table1 這樣返回的值是null

select isnull(id,0) from table1 where 1=0 返回的值是null

這裡 executescalar 的規則就是,返回第一列,第一行的資料。如果第一列第一行不為空,那麼executescalar就直接對應的dotnet的值。如果有第一行,但是第一 列為空,那麼返回的是 dbnull 。如果一行都沒有,那麼executescalar就返回null

規則就是這樣的。這裡容易犯的乙個錯誤是,把executescalar返回dbnull與null的情況混淆,例如:

string username=cmd.executescalar().tostring();

除非你認為cmd執行後,肯定至少有一行資料,否則這裡就會出錯。

又或者 select id from usertable where username=@name 這樣的sql語句,如果找不到記錄,那麼executescalar則會返回null,所以千萬不要

int userid=convert.toint32(cmd.executescalar());

或者你會這樣寫 sql 語句:select isnull(id,0) from usertable where username=@name

但是 int userid=convert.toint32(cmd.executescalar()); 依然會出錯,因為上面的語句不成立時,仍然是不返回任何行。

對於idbdataparameter(oleddbparameter,sqlparameter..)的value,如果為null,則代表該引數沒有指定,或者是代表default。如果為dbnull.value,則代表sql中的null

所以,如果你要呼叫儲存過程,裡面有引數 @val nvarchar(20)="aabb" ,

那麼cmd.parameters["@val"].value=null 代表使用這個預設的 "aabb"

而cmd.parameters["@val"].value=dbnull.value 代表使用null來傳給 @val

你可以用convert.isdbnull來判斷乙個值是否dbnull。注意convert.isdbnull(null)是false。

「等燈 等燈等燈」, 和 的區別

小記錄。是相等操作符,是全等操作符 的判斷標準為兩個運算元相等則返回true,的判斷標誌是兩個運算元未經轉換就相等則返回true 相等操作符的轉換規則 如果有乙個運算元是布林值,則在比較相等性之前先將其轉換為數值,false轉換為0,而true轉換為1 乙個運算元是字串,另乙個運算元是數值,則在比較...

等保1 0與等保2 0的區別

等保1.0與等保2.0的區別 等保2.0於2019.12.1日起正式實施,與等保1.0的相差甚大,下面將從幾個方面對二者的區別進行介紹。標準名稱變化 gb t 22239 2008 資訊保安技術 資訊系統安全等級保護基本要求 改為 gb t 22239 2019 資訊保安技術 網路安全等級保護基本要...

等保1 0與等保2 0的區別

等保2.0於2019.12.1日起正式實施,與等保1.0的相差甚大,下面將從幾個方面對二者的區別進行介紹。gb t 22239 2008 資訊保安技術 資訊系統安全等級保護基本要求 改為 gb t 22239 2019 資訊保安技術 網路安全等級保護基本要求 gb t 25070 2019 資訊保安...