Partager via


DBNull Classe

Définition

Représente une valeur qui n'existe pas. Cette classe ne peut pas être héritée.

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
Héritage
DBNull
Attributs
Implémente

Exemples

L’exemple suivant appelle la DBNull.Value.Equals méthode pour déterminer si un champ de base de données dans une base de données de contacts a une valeur valide. Si c’est le cas, la valeur du champ est ajoutée à la sortie de chaîne dans une étiquette.

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

Remarques

La DBNull classe représente une valeur inexistante. Dans une base de données, par exemple, une colonne dans une ligne d’une table peut ne contenir aucune donnée. Autrement dit, la colonne est considérée comme n’existe pas du tout au lieu de simplement ne pas avoir de valeur. Un DBNull objet représente la colonne inexistante. En outre, l’interopérabilité COM utilise la classe pour faire la DBNull distinction entre une variante VT_NULL, qui indique une valeur inexistante, et une variante VT_EMPTY, qui indique une valeur non spécifiée.

Le DBNull type est une classe singleton, ce qui signifie qu’il n’existe qu’un DBNull seul objet. Le DBNull.Value membre représente le seul DBNull objet. DBNull.Value peut être utilisé pour affecter explicitement une valeur inexistante à un champ de base de données, bien que la plupart des fournisseurs de données ADO.NET attribuent automatiquement des valeurs de DBNull quand un champ n’a pas de valeur valide. Vous pouvez déterminer si une valeur récupérée à partir d’un champ de base de données est une DBNull valeur en passant la valeur de ce champ à la DBNull.Value.Equals méthode . Toutefois, certains langages et objets de base de données fournissent des méthodes qui permettent de déterminer plus facilement si la valeur d’un champ de base de données est DBNull.Value. Il s’agit notamment de la fonction Visual Basic IsDBNull , de la Convert.IsDBNull méthode, de la DataTableReader.IsDBNull méthode et de la IDataRecord.IsDBNull méthode.

Ne confondez pas la notion de dans un langage de null programmation orienté objet avec un DBNull objet. Dans un langage de programmation orienté objet, null signifie l’absence de référence à un objet. DBNull représente une colonne de base de données variant non initialisée ou inexistante.

Champs

Value

Représente l'instance unique de la classe DBNull.

Méthodes

Equals(Object)

Détermine si l'objet spécifié est égal à l'objet actuel.

(Hérité de Object)
GetHashCode()

Fait office de fonction de hachage par défaut.

(Hérité de Object)
GetObjectData(SerializationInfo, StreamingContext)
Obsolète.

Implémente l'interface ISerializable et retourne les données requises pour sérialiser l'objet DBNull.

GetType()

Obtient le Type de l'instance actuelle.

(Hérité de Object)
GetTypeCode()

Obtient la valeur TypeCode pour DBNull.

MemberwiseClone()

Crée une copie superficielle du Object actuel.

(Hérité de Object)
ToString()

Retourne une chaîne vide (Empty).

ToString(IFormatProvider)

Retourne une chaîne vide à l'aide du IFormatProvider spécifié.

Implémentations d’interfaces explicites

IConvertible.ToBoolean(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToByte(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToChar(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToDateTime(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToDecimal(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToDouble(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToInt16(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToInt32(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToInt64(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToSByte(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToSingle(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToType(Type, IFormatProvider)

Convertit l'objet DBNull en cours dans le type spécifié.

IConvertible.ToUInt16(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToUInt32(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

IConvertible.ToUInt64(IFormatProvider)

Cette conversion n'est pas prise en charge. Toute tentative de réalisation de cette conversion lève InvalidCastException.

S’applique à

Voir aussi