DBNull Klasa
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Reprezentuje nieistnieną wartość. Klasa ta nie może być dziedziczona.
public ref class DBNull sealed
public ref class DBNull sealed : IConvertible, System::Runtime::Serialization::ISerializable
public sealed class DBNull
public sealed class DBNull : IConvertible, System.Runtime.Serialization.ISerializable
[System.Serializable]
public sealed class DBNull : IConvertible, System.Runtime.Serialization.ISerializable
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class DBNull : IConvertible, System.Runtime.Serialization.ISerializable
type DBNull = class
type DBNull = class
interface IConvertible
interface ISerializable
[<System.Serializable>]
type DBNull = class
interface ISerializable
interface IConvertible
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type DBNull = class
interface ISerializable
interface IConvertible
Public NotInheritable Class DBNull
Public NotInheritable Class DBNull
Implements IConvertible, ISerializable
- Dziedziczenie
-
DBNull
- Atrybuty
- Implementuje
Przykłady
Poniższy przykład wywołuje metodę , DBNull.Value.Equals
aby określić, czy pole bazy danych w bazie danych kontaktów ma prawidłową wartość. Jeśli tak, wartość pola jest dołączana do danych wyjściowych ciągu w etykiecie.
private void OutputLabels(DataTable dt)
{
string label;
// Iterate rows of table
foreach (DataRow row in dt.Rows)
{
int labelLen;
label = String.Empty;
label += AddFieldValue(label, row, "Title");
label += AddFieldValue(label, row, "FirstName");
label += AddFieldValue(label, row, "MiddleInitial");
label += AddFieldValue(label, row, "LastName");
label += AddFieldValue(label, row, "Suffix");
label += "\n";
label += AddFieldValue(label, row, "Address1");
label += AddFieldValue(label, row, "AptNo");
label += "\n";
labelLen = label.Length;
label += AddFieldValue(label, row, "Address2");
if (label.Length != labelLen)
label += "\n";
label += AddFieldValue(label, row, "City");
label += AddFieldValue(label, row, "State");
label += AddFieldValue(label, row, "Zip");
Console.WriteLine(label);
Console.WriteLine();
}
}
private string AddFieldValue(string label, DataRow row,
string fieldName)
{
if (! DBNull.Value.Equals(row[fieldName]))
return (string) row[fieldName] + " ";
else
return String.Empty;
}
member this.OutputLabels(dt: DataTable) =
let mutable label = ""
// Iterate rows of table
for row in dt.Rows do
let mutable label = String.Empty
label <- label + this.AddFieldValue(label, row, "Title")
label <- label + this.AddFieldValue(label, row, "FirstName")
label <- label + this.AddFieldValue(label, row, "MiddleInitial")
label <- label + this.AddFieldValue(label, row, "LastName")
label <- label + this.AddFieldValue(label, row, "Suffix")
label <- label + "\n"
label <- label + this.AddFieldValue(label, row, "Address1")
label <- label + this.AddFieldValue(label, row, "AptNo")
label <- label + "\n"
let labelLen = label.Length
label <- label + this.AddFieldValue(label, row, "Address2")
let labelLen =
if label.Length <> labelLen then
label + "\n"
else label
label <- label + this.AddFieldValue(label, row, "City")
label <- label + this.AddFieldValue(label, row, "State")
label <- label + this.AddFieldValue(label, row, "Zip")
printfn $"{label}"
printfn ""
member _.AddFieldValue(label: string, row: DataRow, fieldName: string) =
if DBNull.Value.Equals row[fieldName] |> not then
(string row[fieldName]) + " "
else
String.Empty
Private Sub OUtputLabels(dt As DataTable)
Dim label As String
' Iterate rows of table
For Each row As DataRow In dt.Rows
Dim labelLen As Integer
label = String.Empty
label += AddFieldValue(label, row, "Title")
label += AddFieldValue(label, row, "FirstName")
label += AddFieldValue(label, row, "MiddleInitial")
label += AddFieldValue(label, row, "LastName")
label += AddFieldValue(label, row, "Suffix")
label += vbCrLf
label += AddFieldValue(label, row, "Address1")
label += AddFieldValue(label, row, "AptNo")
label += vbCrLf
labelLen = Len(label)
label += AddFieldValue(label, row, "Address2")
If Len(label) <> labelLen Then label += vbCrLf
label += AddFieldValue(label, row, "City")
label += AddFieldValue(label, row, "State")
label += AddFieldValue(label, row, "Zip")
Console.WriteLine(label)
Console.WriteLine()
Next
End Sub
Private Function AddFieldValue(label As String, row As DataRow, _
fieldName As String) As String
If Not DbNull.Value.Equals(row.Item(fieldName)) Then
Return CStr(row.Item(fieldName)) & " "
Else
Return Nothing
End If
End Function
Uwagi
Klasa DBNull reprezentuje nieistnieną wartość. Na przykład w bazie danych kolumna w wierszu tabeli może nie zawierać żadnych danych. Oznacza to, że kolumna nie istnieje w ogóle, a nie tylko nie ma wartości. Obiekt DBNull reprezentuje nieistnieną kolumnę. Ponadto międzyoperacyjności modelu COM używa DBNull klasy do odróżnienia od wariantu VT_NULL, który wskazuje nieistnieną wartość i wariant VT_EMPTY, który wskazuje nieokreśloną wartość.
Typ DBNull jest pojedynczą klasą, co oznacza, że istnieje tylko jeden DBNull obiekt. Element DBNull.Value członkowski reprezentuje jedyny DBNull obiekt.
DBNull.Value Może służyć do jawnego przypisania nieistniejących wartości do pola bazy danych, chociaż większość dostawców danych ADO.NET automatycznie przypisuje wartości DBNull , gdy pole nie ma prawidłowej wartości. Można określić, czy wartość pobrana z pola bazy danych jest wartością DBNull , przekazując wartość tego pola do DBNull.Value.Equals
metody . Jednak niektóre języki i obiekty bazy danych udostępniają metody, które ułatwiają ustalenie, czy wartość pola bazy danych to DBNull.Value. Obejmują one funkcję Języka Visual Basic IsDBNull
, Convert.IsDBNull metodę, DataTableReader.IsDBNull metodę i metodę IDataRecord.IsDBNull .
Nie należy mylić pojęcia null
w języku programowania obiektowym z obiektem DBNull . W języku null
programowania obiektowym oznacza brak odwołania do obiektu.
DBNull reprezentuje niezainicjowany wariant lub nieistnieną kolumnę bazy danych.
Pola
Value |
Reprezentuje jedyne wystąpienie DBNull klasy. |
Metody
Equals(Object) |
Określa, czy dany obiekt jest taki sam, jak bieżący obiekt. (Odziedziczone po Object) |
GetHashCode() |
Służy jako domyślna funkcja skrótu. (Odziedziczone po Object) |
GetObjectData(SerializationInfo, StreamingContext) |
Przestarzałe.
Implementuje ISerializable interfejs i zwraca dane potrzebne do serializacji DBNull obiektu. |
GetType() |
Type Pobiera wartość bieżącego wystąpienia. (Odziedziczone po Object) |
GetTypeCode() | |
MemberwiseClone() |
Tworzy płytkią kopię bieżącego Objectelementu . (Odziedziczone po Object) |
ToString() |
Zwraca pusty ciąg (Empty). |
ToString(IFormatProvider) |
Zwraca pusty ciąg przy użyciu określonego IFormatProviderelementu . |
Jawne implementacje interfejsu
IConvertible.ToBoolean(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToByte(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToChar(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToDateTime(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToDecimal(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToDouble(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToInt16(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToInt32(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToInt64(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToSByte(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToSingle(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToType(Type, IFormatProvider) |
Konwertuje bieżący DBNull obiekt na określony typ. |
IConvertible.ToUInt16(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToUInt32(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |
IConvertible.ToUInt64(IFormatProvider) |
Ta konwersja nie jest obsługiwana. Próba wykonania tej konwersji powoduje zgłoszenie błędu InvalidCastException. |