2012-02-15 25 views
0

私はエンティティフレームワークが初めてです。それを使って私の最初のアプリに取り組んでいます。これまでのところ、私はそれが大好き!私は、EFのコンテキストでテーブル/クエリ内のフィールドと対話する強く型付けされた方法が本当に好きです。EFでフィールドを名前で指定する方法はありますか?

しかし、テーブル/クエリのフィールドにアクセスする方法があるかどうか、古いファッションの方法では、フィールドを文字列として指定することができますか?例えば、efObjectは.EDMXでいくつかのテーブルであると仮定すると、このような何かを行う方法があります:

efObject["FirstName"].Value = "Fred"; 

これを行うような方法があれば、私は性質が何であるかを知りませんどのような方法になるのかなど。

私はEF 4.2で作業しています。

+0

強力な型付きのアクセス方法が得られたのはなぜですか? –

+0

良い質問です。問題は、私がADO.NETデータセットを返す前に書いたWCFサービスがあることです。私が知っている唯一の方法は、それが返すすべてのテーブルを反復することです(そして、たくさんのフィールドがあります)。 dataSet.Tables [n] .Rows [m] [o ]; – Rod

+0

(私のコメントにキャリッジリターンを入れることができないことに慣れていません) また、dataSet.Tables [n] .Rows [m] ["FirstName"] 私はそうではありませんEFモデルの各テーブルの各列ごとにコード行を入力する必要があります。すべてのテーブルに約600のフィールドがあります。それは、私が避けようとしているたくさんのタイプの入力です。 – Rod

答えて

1

実行時にEFデータモデルの定義に簡単にアクセスすることはできません。

はな理由とその回避策については、この議論を見てください:Get Database Table Name from Entity Framework MetaData

プロパティ名と、それぞれのフィールド名が一致し、あなたがマッピングを控除するためにリフレクションを使用することができます。

+0

ありがとう、Dennis、リンク先の他のStack Overflow記事。うわー、それは簡単ではないように見えます。あなたがリンクしている記事では、Rick Strahlがテーブル名を望んでいました。私はそれを知っています、それは私が知らない分野です。 ObjectStateEntry、またはリストされた他のオプションについては、それらを使用するために何も知りません。おそらくこの場合は、データを移動しようとしているローカルのSQL Expressデータベースに対してADO.NETデータセットを使用するほうがよいでしょう。 Bummer。 – Rod

関連する問題