Udostępnij za pośrednictwem


DBNull Klasa

Definicja

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()

TypeCode Pobiera wartość dla DBNull.

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.

Dotyczy

Zobacz też