DBNull Classe
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
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() | |
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. |