[解決済み] IEnumerable<T> と IQueryable<T> を比較する。
2022-03-17 22:07:02
質問
を返すのとどう違うのですか?
IQueryable<T>
vs.
IEnumerable<T>
どのような場合に、どちらを優先させるべきでしょうか?
IQueryable<Customer> custs = from c in db.Customers
where c.City == "<City>"
select c;
IEnumerable<Customer> custs = from c in db.Customers
where c.City == "<City>"
select c;
どちらも執行猶予になるのでしょうか、また、どのような場合にどちらを優先すべきなのでしょうか?
どのように解決するのですか?
はい、どちらもお渡しします。 遅延実行 .
という違いがあります。
IQueryable<T>
は、LINQ-to-SQL(実際にはLINQ.-to-anything)を動作させるためのインタフェースです。したがって、もしあなたが
IQueryable<T>
そのクエリーは、可能であれば、データベースで実行されます。
については
IEnumerable<T>
の場合、LINQ-to-Objectとなり、元のクエリにマッチするすべてのオブジェクトがデータベースからメモリにロードされなければならないことを意味します。
コードでは
IQueryable<Customer> custs = ...;
// Later on...
var goldCustomers = custs.Where(c => c.IsGold);
このコードでは、ゴールドの顧客のみを選択するSQLを実行します。一方、次のコードは、データベースで元のクエリを実行し、メモリ内でゴールド以外の顧客をフィルタリングします。
IEnumerable<Customer> custs = ...;
// Later on...
var goldCustomers = custs.Where(c => c.IsGold);
これはかなり重要な違いで
IQueryable<T>
は、多くの場合、データベースからあまりに多くの行を返さなくて済むようにします。もう一つの典型的な例は、ページングを行うことです。もし
Take
と
Skip
について
IQueryable
の場合、要求された行数しか取得できません。
IEnumerable<T>
を使用すると、すべての行がメモリに読み込まれることになります。
関連
-
[解決済み】「The breakpoint will not currently be hit」を改善するには?このドキュメントにはシンボルが読み込まれていません。" という警告はどうすれば改善されますか?
-
[解決済み】指定されたキャストが有効でない?
-
[解決済み】ファイルやアセンブリ、またはその依存関係の1つをロードできませんでした。
-
[解決済み] C#のconstとreadonlyの違いは何ですか?
-
[解決済み] キーワード「ref」と「out」の違いは何ですか?
-
[解決済み] IEnumerable<T>のforeachのLINQでの等価性
-
[解決済み] ダイレクトキャスト vs 'as'演算子?
-
[解決済み] IEnumerable<T> / IQueryable<T>の動的なLINQ OrderBy
-
[解決済み] int.Parse()とConvert.ToInt32の主な違いは何ですか?
-
[解決済み】IEnumerable vs List - What to Use? どのように動作するのでしょうか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] [Solved] 1つ以上のエンティティで検証に失敗しました。詳細は'EntityValidationErrors'プロパティを参照してください [重複]。
-
[解決済み】GDI+、JPEG画像をMemoryStreamに変換する際にジェネリックエラーが発生しました。
-
[解決済み】"The ConnectionString property has not been initialized "を修正する方法
-
[解決済み】WPFでXamlファイルにコメントを追加する方法は?
-
[解決済み] [Solved] 不正な文字列値: '\xEFxBFxBD' for column
-
[解決済み】MetadataException: 指定されたメタデータ・リソースをロードできない
-
[解決済み】5.7.57 SMTP - MAIL FROMエラー時に匿名メールを送信するためにクライアントが認証されない
-
[解決済み】Linq 構文 - 複数列の選択
-
[解決済み】プロセスが実行されているかどうかを知るには?
-
[解決済み】IEnumerable vs List - What to Use? どのように動作するのでしょうか?