DBNull DBNull DBNull DBNull Class

定義

存在しない値を表します。Represents a nonexistent value. このクラスは継承できません。This class cannot be inherited.

public ref class DBNull sealed : 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
継承
DBNullDBNullDBNullDBNull
属性
実装

次の例では、DBNull.Value.Equals連絡先データベースのデータベース フィールドに有効な値があるかどうかを判断するメソッド。The following example calls the DBNull.Value.Equals method to determine whether a database field in a contacts database has a valid value. 場合は、ラベルの文字列出力フィールドの値が追加されます。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

注釈

DBNullクラスが存在しない値を表します。The DBNull class represents a nonexistent value. データベースでは、たとえば、テーブルの行の列には可能性がありますが含まれていないデータには。In a database, for example, a column in a row of a table might not contain any data whatsoever. つまり、列が値を持っていないだけではなく、まったく存在しないと見なされます。That is, the column is considered to not exist at all instead of merely not having a value. ADBNullオブジェクトが存在しない列を表します。A DBNull object represents the nonexistent column. さらに、COM 相互運用機能を使用して、DBNullクラスが存在しない値を示す、VT_ バリアント型と VT_EMPTY バリアント型は、指定されていない値を示しますとを区別します。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.

DBNull型が、1 つだけのことを意味するシングルトン クラスDBNullオブジェクトが存在します。The DBNull type is a singleton class, which means only one DBNull object exists. DBNull.Valueメンバーが、唯一を表すDBNullオブジェクト。The DBNull.Value member represents the sole DBNull object. DBNull.Value データベースのフィールドに存在しない値を明示的に割り当てるを使用できますが、ほとんどの ADO.NET データ プロバイダーが自動的の値を割り当てるDBNullときに、フィールドには有効な値はありません。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. データベースのフィールドから取得した値があるかどうかを判断できます、DBNull値には、そのフィールドの値を渡すことによって、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. ただし、一部の言語とデータベース オブジェクト、データベース フィールドの値があるかどうかを判断するが簡単にする方法を指定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. Visual Basic が含まれますIsDBNull関数、Convert.IsDBNullメソッド、DataTableReader.IsDBNullメソッド、およびIDataRecord.IsDBNullメソッド。These include the Visual Basic IsDBNull function, the Convert.IsDBNull method, the DataTableReader.IsDBNull method, and the IDataRecord.IsDBNull method.

概念を混同しないでくださいnullでオブジェクト指向のプログラミング言語で、DBNullオブジェクト。Do not confuse the notion of null in an object-oriented programming language with a DBNull object. オブジェクト指向のプログラミング言語でnullオブジェクトへの参照がないことを意味します。In an object-oriented programming language, null means the absence of a reference to an object. DBNull 初期化されていないバリアントまたは存在しないデータベースの列を表します。DBNull represents an uninitialized variant or nonexistent database column.

フィールド

Value Value Value Value

DBNull クラスの唯一のインスタンスを表します。Represents the sole instance of the DBNull class.

メソッド

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

指定したオブジェクトが、現在のオブジェクトと等しいかどうかを判断します。Determines whether the specified object is equal to the current object.

(Inherited from Object)
GetHashCode() GetHashCode() GetHashCode() GetHashCode()

既定のハッシュ関数として機能します。Serves as the default hash function.

(Inherited from Object)
GetObjectData(SerializationInfo, StreamingContext) GetObjectData(SerializationInfo, StreamingContext) GetObjectData(SerializationInfo, StreamingContext) GetObjectData(SerializationInfo, StreamingContext)

ISerializable インターフェイスを実装し、DBNull オブジェクトをシリアル化するために必要なデータを返します。Implements the ISerializable interface and returns the data needed to serialize the DBNull object.

GetType() GetType() GetType() GetType()

現在のインスタンスの Type を取得します。Gets the Type of the current instance.

(Inherited from Object)
GetTypeCode() GetTypeCode() GetTypeCode() GetTypeCode()

TypeCodeDBNull 値を取得します。Gets the TypeCode value for DBNull.

MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

現在の Object の簡易コピーを作成します。Creates a shallow copy of the current Object.

(Inherited from Object)
ToString() ToString() ToString() ToString()

空の文字列 (Empty) を返します。Returns an empty string (Empty).

ToString(IFormatProvider) ToString(IFormatProvider) ToString(IFormatProvider) ToString(IFormatProvider)

指定した IFormatProvider を使用して、空の文字列を返します。Returns an empty string using the specified IFormatProvider.

明示的なインターフェイスの実装

IConvertible.ToBoolean(IFormatProvider) IConvertible.ToBoolean(IFormatProvider) IConvertible.ToBoolean(IFormatProvider) IConvertible.ToBoolean(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToByte(IFormatProvider) IConvertible.ToByte(IFormatProvider) IConvertible.ToByte(IFormatProvider) IConvertible.ToByte(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToChar(IFormatProvider) IConvertible.ToChar(IFormatProvider) IConvertible.ToChar(IFormatProvider) IConvertible.ToChar(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToDateTime(IFormatProvider) IConvertible.ToDateTime(IFormatProvider) IConvertible.ToDateTime(IFormatProvider) IConvertible.ToDateTime(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToDecimal(IFormatProvider) IConvertible.ToDecimal(IFormatProvider) IConvertible.ToDecimal(IFormatProvider) IConvertible.ToDecimal(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToDouble(IFormatProvider) IConvertible.ToDouble(IFormatProvider) IConvertible.ToDouble(IFormatProvider) IConvertible.ToDouble(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToInt16(IFormatProvider) IConvertible.ToInt16(IFormatProvider) IConvertible.ToInt16(IFormatProvider) IConvertible.ToInt16(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToInt32(IFormatProvider) IConvertible.ToInt32(IFormatProvider) IConvertible.ToInt32(IFormatProvider) IConvertible.ToInt32(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToInt64(IFormatProvider) IConvertible.ToInt64(IFormatProvider) IConvertible.ToInt64(IFormatProvider) IConvertible.ToInt64(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToSByte(IFormatProvider) IConvertible.ToSByte(IFormatProvider) IConvertible.ToSByte(IFormatProvider) IConvertible.ToSByte(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToSingle(IFormatProvider) IConvertible.ToSingle(IFormatProvider) IConvertible.ToSingle(IFormatProvider) IConvertible.ToSingle(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToType(Type, IFormatProvider) IConvertible.ToType(Type, IFormatProvider) IConvertible.ToType(Type, IFormatProvider) IConvertible.ToType(Type, IFormatProvider)

現在の DBNull オブジェクトを指定した型に変換します。Converts the current DBNull object to the specified type.

IConvertible.ToUInt16(IFormatProvider) IConvertible.ToUInt16(IFormatProvider) IConvertible.ToUInt16(IFormatProvider) IConvertible.ToUInt16(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToUInt32(IFormatProvider) IConvertible.ToUInt32(IFormatProvider) IConvertible.ToUInt32(IFormatProvider) IConvertible.ToUInt32(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

IConvertible.ToUInt64(IFormatProvider) IConvertible.ToUInt64(IFormatProvider) IConvertible.ToUInt64(IFormatProvider) IConvertible.ToUInt64(IFormatProvider)

この変換はサポートされていません。This conversion is not supported. この変換を試みると、InvalidCastException がスローされます。Attempting to make this conversion throws an InvalidCastException.

適用対象

こちらもご覧ください