DBNull Clase

Definición

Representa un valor no existente.Represents a nonexistent value. No se puede heredar esta clase.This class cannot be inherited.

public ref class DBNull sealed : IConvertible, System::Runtime::Serialization::ISerializable
public sealed class DBNull : IConvertible, System.Runtime.Serialization.ISerializable
[System.Serializable]
public sealed class DBNull : IConvertible, System.Runtime.Serialization.ISerializable
[System.Runtime.InteropServices.ComVisible(true)]
[System.Serializable]
public sealed class DBNull : IConvertible, System.Runtime.Serialization.ISerializable
type DBNull = class
    interface ISerializable
    interface IConvertible
Public NotInheritable Class DBNull
Implements IConvertible, ISerializable
Herencia
DBNull
Atributos
Implementaciones

Ejemplos

En el ejemplo siguiente se llama al método DBNull.Value.Equals para determinar si un campo de base de datos de una base de datos de contactos tiene un valor válido.The following example calls the DBNull.Value.Equals method to determine whether a database field in a contacts database has a valid value. Si es así, el valor del campo se anexa a la salida de la cadena en una etiqueta.If it does, the field value is appended to the string output in a label.

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;
}
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

Comentarios

La clase DBNull representa un valor inexistente.The DBNull class represents a nonexistent value. En una base de datos, por ejemplo, una columna de una fila de una tabla podría no contener ningún dato.In a database, for example, a column in a row of a table might not contain any data whatsoever. Es decir, se considera que la columna no existe en absoluto en lugar de simplemente no tener un valor.That is, the column is considered to not exist at all instead of merely not having a value. Un objeto DBNull representa la columna inexistente.A DBNull object represents the nonexistent column. Además, la interoperabilidad COM usa la clase DBNull para distinguir entre una variante VT_NULL, que indica un valor inexistente, y una variante VT_EMPTY, que indica un valor no especificado.Additionally, COM interop uses the DBNull class to distinguish between a VT_NULL variant, which indicates a nonexistent value, and a VT_EMPTY variant, which indicates an unspecified value.

El DBNull tipo es una clase singleton, lo que significa que solo existe un objeto DBNull.The DBNull type is a singleton class, which means only one DBNull object exists. El miembro DBNull.Value representa el único objeto DBNull.The DBNull.Value member represents the sole DBNull object. DBNull.Value se puede usar para asignar explícitamente un valor no existente a un campo de base de datos, aunque la mayoría de los proveedores de datos ADO.NET asignan automáticamente valores de DBNull cuando un campo no tiene un valor válido.DBNull.Value can be used to explicitly assign a nonexistent value to a database field, although most ADO.NET data providers automatically assign values of DBNull when a field does not have a valid value. Puede determinar si un valor recuperado de un campo de base de datos es un valor DBNull pasando el valor de ese campo al método DBNull.Value.Equals.You can determine whether a value retrieved from a database field is a DBNull value by passing the value of that field to the DBNull.Value.Equals method. Sin embargo, algunos lenguajes y objetos de base de datos proporcionan métodos que facilitan la determinación de si el valor de un campo de base de datos es DBNull.Value.However, some languages and database objects supply methods that make it easier to determine whether the value of a database field is DBNull.Value. Entre ellas se incluyen la función IsDBNull Visual Basic, el método Convert.IsDBNull, el método DataTableReader.IsDBNull y el método IDataRecord.IsDBNull.These include the Visual Basic IsDBNull function, the Convert.IsDBNull method, the DataTableReader.IsDBNull method, and the IDataRecord.IsDBNull method.

No confunda el concepto de null en un lenguaje de programación orientado a objetos con un objeto DBNull.Do not confuse the notion of null in an object-oriented programming language with a DBNull object. En un lenguaje de programación orientado a objetos, null significa la ausencia de una referencia a un objeto.In an object-oriented programming language, null means the absence of a reference to an object. DBNull representa una variante no inicializada o una columna de base de datos inexistente.DBNull represents an uninitialized variant or nonexistent database column.

Campos

Value

Representa la única instancia de la clase DBNull.Represents the sole instance of the DBNull class.

Métodos

Equals(Object)

Determina si el objeto especificado es igual que el objeto actual.Determines whether the specified object is equal to the current object.

(Heredado de Object)
GetHashCode()

Sirve como función hash predeterminada.Serves as the default hash function.

(Heredado de Object)
GetObjectData(SerializationInfo, StreamingContext)

Implementa la interfaz ISerializable y devuelve los datos necesarios para serializar el objeto DBNull.Implements the ISerializable interface and returns the data needed to serialize the DBNull object.

GetType()

Obtiene el Type de la instancia actual.Gets the Type of the current instance.

(Heredado de Object)
GetTypeCode()

Obtiene el valor TypeCode para DBNull.Gets the TypeCode value for DBNull.

MemberwiseClone()

Crea una copia superficial del objeto Object actual.Creates a shallow copy of the current Object.

(Heredado de Object)
ToString()

Devuelve una cadena vacía (Empty).Returns an empty string (Empty).

ToString(IFormatProvider)

Devuelve una cadena vacía mediante IFormatProvider.Returns an empty string using the specified IFormatProvider.

Implementaciones de interfaz explícitas

IConvertible.ToBoolean(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToByte(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToChar(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToDateTime(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToDecimal(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToDouble(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToInt16(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToInt32(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToInt64(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToSByte(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToSingle(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToType(Type, IFormatProvider)

Convierte el objeto DBNull actual al tipo especificado.Converts the current DBNull object to the specified type.

IConvertible.ToUInt16(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToUInt32(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToUInt64(IFormatProvider)

No se admite esta conversión.This conversion is not supported. Si se intenta realizar esta conversión, se produce una excepción InvalidCastException.Attempting to make this conversion throws an InvalidCastException.

Se aplica a

Consulte también: