DBNull Classe
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Représente une valeur inexistante. 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 d’une base de données 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 d’une ligne d’une table peut ne pas contenir de données. Autrement dit, la colonne est considérée comme n’existe pas du tout au lieu de ne pas avoir simplement une valeur. Un DBNull objet représente la colonne inexistante. En outre, COM Interop 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’un DBNull seul objet existe. Le DBNull.Value membre représente l’objet unique DBNull .
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 lorsqu’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 facilitent la détermination de la valeur d’un champ DBNull.Valuede base de données. Il s’agit notamment de la fonction Visual Basic IsDBNull, de la méthode Convert.IsDBNull, de la méthode DataTableReader.IsDBNull et de la méthode IDataRecord.IsDBNull.
Ne confondez pas la notion de langage de null programmation orienté objet avec un DBNull objet. Dans un langage de programmation orienté objet, null signifie l’absence d’une référence à un objet.
DBNull représente une colonne de base de données non initialisée ou non initialisée.
Champs
| Nom | Description |
|---|---|
| Value |
Représente la seule instance de la DBNull classe. |
Méthodes
| Nom | Description |
|---|---|
| Equals(Object) |
Détermine si l’objet spécifié est égal à l’objet actuel. (Hérité de Object) |
| GetHashCode() |
Sert 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 nécessaires pour sérialiser l’objet DBNull . |
| GetType() |
Obtient la Type de l’instance actuelle. (Hérité de Object) |
| GetTypeCode() | |
| MemberwiseClone() |
Crée une copie superficielle du Objectactuel. (Hérité de Object) |
| ToString() |
Retourne une chaîne vide (Empty). |
| ToString(IFormatProvider) |
Retourne une chaîne vide à l’aide de l’objet spécifié IFormatProvider. |
Implémentations d’interfaces explicites
| Nom | Description |
|---|---|
| IConvertible.ToBoolean(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToByte(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToChar(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToDateTime(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToDecimal(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToDouble(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToInt16(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToInt32(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToInt64(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToSByte(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToSingle(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToType(Type, IFormatProvider) |
Convertit l’objet actuel DBNull en type spécifié. |
| IConvertible.ToUInt16(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToUInt32(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |
| IConvertible.ToUInt64(IFormatProvider) |
Cette conversion n’est pas prise en charge. La tentative d’effectuer cette conversion lève un InvalidCastException. |