DBNull Classe
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Representa um valor inexistente. Essa classe não pode ser herdada.
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
- Herança
-
DBNull
- Atributos
- Implementações
Exemplos
O exemplo a seguir chama o DBNull.Value.Equals
método para determinar se um campo de banco de dados em um banco de dados de contatos tem um valor válido. Se isso acontecer, o valor do campo será acrescentado à saída da cadeia de caracteres em um rótulo.
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
Comentários
A DBNull classe representa um valor inexistente. Em um banco de dados, por exemplo, uma coluna em uma linha de uma tabela pode não conter nenhum dado. Ou seja, a coluna é considerada como não existir em vez de simplesmente não ter um valor. Um DBNull objeto representa a coluna inexistente. Além disso, a interoperabilidade COM usa a DBNull classe para distinguir entre uma variante VT_NULL, que indica um valor inexistente e uma variante VT_EMPTY, que indica um valor não especificado.
O DBNull tipo é uma classe singleton, o que significa que existe apenas um DBNull objeto. O DBNull.Value membro representa o único DBNull objeto.
DBNull.Value pode ser usado para atribuir explicitamente um valor inexistente a um campo de banco de dados, embora a maioria dos provedores de dados ADO.NET atribua automaticamente valores de DBNull quando um campo não tem um valor válido. Você pode determinar se um valor recuperado de um campo de banco de dados é um DBNull valor passando o valor desse campo para o DBNull.Value.Equals
método . No entanto, alguns idiomas e objetos de banco de dados fornecem métodos que facilitam a determinação do valor de um campo de banco de dados.DBNull.Value Eles incluem a função Visual Basic IsDBNull
, o Convert.IsDBNull método, o DataTableReader.IsDBNull método e o IDataRecord.IsDBNull método .
Não confunda a noção de null
em uma linguagem de programação orientada a objeto com um DBNull objeto . Em uma linguagem de programação orientada a objetos, null
significa a ausência de uma referência a um objeto .
DBNull representa uma coluna de banco de dados variante não inicializada ou inexistente.
Campos
Value |
Representa a instância exclusiva da classe DBNull. |
Métodos
Equals(Object) |
Determina se o objeto especificado é igual ao objeto atual. (Herdado de Object) |
GetHashCode() |
Serve como a função de hash padrão. (Herdado de Object) |
GetObjectData(SerializationInfo, StreamingContext) |
Obsoleto.
Implementa a interface ISerializable e retorna os dados necessários para serializar o objeto DBNull. |
GetType() |
Obtém o Type da instância atual. (Herdado de Object) |
GetTypeCode() | |
MemberwiseClone() |
Cria uma cópia superficial do Object atual. (Herdado de Object) |
ToString() |
Retorna uma cadeia de caracteres vazia (Empty). |
ToString(IFormatProvider) |
Retorna uma cadeia de caracteres vazia usando o especificado IFormatProvider. |
Implantações explícitas de interface
IConvertible.ToBoolean(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToByte(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToChar(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToDateTime(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToDecimal(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToDouble(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToInt16(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToInt32(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToInt64(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToSByte(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToSingle(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToType(Type, IFormatProvider) |
Converte o objeto DBNull atual no tipo especificado. |
IConvertible.ToUInt16(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToUInt32(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |
IConvertible.ToUInt64(IFormatProvider) |
Não há suporte para esta conversão. A tentativa de fazer essa conversão gera uma InvalidCastException. |