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 資訊保安...