Condividi tramite


DBNull Classe

Definizione

Rappresenta un valore non esistente. La classe non può essere ereditata.

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
Ereditarietà
DBNull
Attributi
Implementazioni

Esempio

Nell'esempio seguente viene chiamato il DBNull.Value.Equals metodo per determinare se un campo di database in un database contatti ha un valore valido. In caso contrario, il valore del campo viene aggiunto all'output della stringa in un'etichetta.

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

Commenti

La DBNull classe rappresenta un valore inesistente. In un database, ad esempio, una colonna in una riga di una tabella potrebbe non contenere alcun dato. Ovvero, la colonna viene considerata non esistente invece di non avere semplicemente un valore. Un DBNull oggetto rappresenta la colonna inesistente. Inoltre, l'interoperabilità COM usa la DBNull classe per distinguere tra una variante VT_NULL, che indica un valore inesistente e una variante VT_EMPTY, che indica un valore non specificato.

Il DBNull tipo è una classe singleton, ovvero esiste un solo DBNull oggetto. Il DBNull.Value membro rappresenta l'oggetto unico DBNull . DBNull.Value può essere usato per assegnare in modo esplicito un valore non esistente a un campo di database, anche se la maggior parte dei provider di dati ADO.NET assegna automaticamente i valori di DBNull quando un campo non ha un valore valido. È possibile determinare se un valore recuperato da un campo di database è un DBNull valore passando il valore di tale campo al DBNull.Value.Equals metodo. Tuttavia, alcuni linguaggi e oggetti di database forniscono metodi che semplificano la determinazione del valore di un campo di database.DBNull.Value Queste includono la funzione Visual BasicIsDBNull, il Convert.IsDBNull metodo, il metodo e il IDataRecord.IsDBNullDataTableReader.IsDBNull metodo.

Non confondere la nozione di in un linguaggio di null programmazione orientato agli oggetti con un DBNull oggetto. In un linguaggio di programmazione orientato agli oggetti significa null l'assenza di un riferimento a un oggetto. DBNull rappresenta una colonna di database non inizializzata o non esistente.

Campi

Value

Rappresenta l'unica istanza della classe DBNull.

Metodi

Equals(Object)

Determina se l'oggetto specificato è uguale all'oggetto corrente.

(Ereditato da Object)
GetHashCode()

Funge da funzione hash predefinita.

(Ereditato da Object)
GetObjectData(SerializationInfo, StreamingContext)
Obsoleti.

Implementa l'interfaccia ISerializable e restituisce i dati necessari per la serializzazione dell'oggetto DBNull.

GetType()

Ottiene l'oggetto Type dell'istanza corrente.

(Ereditato da Object)
GetTypeCode()

Ottiene il valore TypeCode per DBNull.

MemberwiseClone()

Crea una copia superficiale dell'oggetto Object corrente.

(Ereditato da Object)
ToString()

Restituisce una stringa vuota (Empty).

ToString(IFormatProvider)

Restituisce una stringa vuota usando il IFormatProvider specificato.

Implementazioni dell'interfaccia esplicita

IConvertible.ToBoolean(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToByte(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToChar(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToDateTime(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToDecimal(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToDouble(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToInt16(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToInt32(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToInt64(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToSByte(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToSingle(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToType(Type, IFormatProvider)

Converte l'oggetto DBNull corrente nel tipo specificato.

IConvertible.ToUInt16(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToUInt32(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

IConvertible.ToUInt64(IFormatProvider)

Questa conversione non è supportata. Tentarla genera un'eccezione InvalidCastException.

Si applica a

Vedi anche