以下の2つの違いは何ですか?データテーブルの名前付きフィールドと名前付きカラムの相違点
var dtime = (DateTime)datatable[0]["SomeDateTime"];
var dtime = datatable[0].field<DateTime>("SomeDateTime");
EDIT と、この最初の行で
var dtime = Convert.ToDateTime(datatable[0]["SomeDateTime"]);
以下の2つの違いは何ですか?データテーブルの名前付きフィールドと名前付きカラムの相違点
var dtime = (DateTime)datatable[0]["SomeDateTime"];
var dtime = datatable[0].field<DateTime>("SomeDateTime");
EDIT と、この最初の行で
var dtime = Convert.ToDateTime(datatable[0]["SomeDateTime"]);
に差が異なる実装を検査することができます
は、第二はDataRow
拡張メソッドField
に舞台裏キャストのに対し、最初は自分で明示的なキャストを使用していることです。日時列がNULL値を含めることができる場合
だからDateTime?
を使用します。
DateTime? dtime = datatable.Rows[0].Field<DateTime?>("SomeDateTime");
だから私はField
を使用することをお勧めします。これは強く型付けされ(キャストを隠す)、null可能な型をサポートします。 (TypeName)
による明示的なキャストも読みにくいです。
Timに感謝します。したがって、データテーブルにnullが含まれている場合、フィールドのみが機能しますか? – nik
@nik:はい、私は例を示しました。 –
var dtime = (DateTime)datatable[0]["SomeDateTime"];
あなたがobject
を返すインデクサプロパティを使用します。そのため、実際にオブジェクトが存在すると予想されるタイプに自分自身をキャストする必要があります。
二ケース
var dtime = datatable[0].Field<DateTime>("SomeDateTime");
はあなたのための鋳造を行うにしようとあなたが(そうDateTime
あなたの例では)指定された型を返すジェネリック拡張メソッドField<T>
を呼び出します。あなたはindexerのリファレンス・ソースとField<T>()
extension method
与えられた例との主な違いは、
(Type)
が今まであなたが持っているタイプと力、それはerroring、そのタイプになるために何を取る変換する方法であり、それ
<Type>
およびConvert.ToType()
は変換のためにコンバータクラスを使用しています。 IConvertableインターフェイスこれは、誰かがそのタイプを変換可能にすることを考えていることを意味します。これは成功した結果を得る可能性が高いことを意味します。
これ以外の場合、名前付きフィールド(このプロパティまたはフィールドメソッド
「データテーブル」とは何ですか?なぜなら、それはコンパイルされない 'DataTable 'だからです。擬似コードを提供するのではなく、コードをコンパイルしてください(またはそれが問題の場合にコンパイルされないコード)。 –
おそらく、あなたはDataRowCollectionについて話しています。あなたの変数の名前をわかりにくくしてください。 – Steve
これはデータテーブルであり、エラーなしでコンパイルされます。私が得る唯一のエラーは例外のキャストです。はい、データテーブルにインデックスを付けることで、実際にはデータローですが、これを変更することはできますが、これは混乱しているとは思いません。 – nik