私は、ユーザが各パラメータで複数の値を持つ複数のパラメータを選択できる機能を開発中です。私は、ストアドプロシージャにマッピングされているエンティティを持つC#、エンティティフレームワークを使用して、アプリケーションでこの機能を設計する方法を理解しようとしています。セキュリティ上の理由から、私のアプリケーションは、ストアドプロシージャだけを持つ代理データベースを介してデータベースにアクセスする必要があります。したがって、私のエンティティは、挿入、更新、および選択のためのストアドプロシージャにマップされます。 最終的には、データベースを照会するために、ユーザーが選択したフィルターをストアード・プロシージャーに渡す必要があります。私が考えていたソリューションの1つは、すべてのデータをビジネスレイヤーに取得し、linqを使用してさらにフィルタリングすることでした。しかし、これは理想的ではない。なぜなら、この種の複雑な照会を行うのにより適しているのは、データベースよりもメモリレーターでフィルターされるデータの量である。 私はlinqを使って動的なクエリを構築するための記事を見ましたが、これらの種類の投稿では、エンティティがテーブルにマップされているため、読みやすくなりました。 ここにお手伝いいただければ幸いです。 ありがとう、 sirkalC#+ Entity Framework +ストアドプロシージャを使用した動的クエリの作成
1
A
答えて
0
EF(とLINQはその点で)遅延実行を使用します。 IQueryable(Googleの検索時間?)を使用し、作成するオブジェクトにフィルタ条件を作成することで、動的クエリを簡単に作成できます(オブジェクトなしで実行できますが、再利用可能と考える)。
SQL sprocに関しては、フィルタを変更する可能性のあるすべての項目を渡して、SQLでデータを動的に処理して結果セットを生成することによっても解決できます。
お選びくださいそれは本当にあなたのグループのコアコンピテンシーがどこにあるかによって異なります。私はC#コードのほうが親しみやすい(sprocsをやっている年を費やしたが、ダイナミックなsprocsは王の痛みになる)ことが多いからだ。
あなたが気にしたいことの1つは、(SQL Serverの統計のような、他のRDBMSでも同様の概念が使用されていますが)サーバーによって簡単に調整できない動的なクエリで終わることです。たとえば、LINQ to SQLで見た1つの問題は、SQLのパフォーマンスを最適化することができない動的クエリーであり、DBAから多くの手持ちを要求しています。
関連する問題
- 1. Entity Framework 4の動的クエリのユニットテスト
- 2. T-SQLストアドプロシージャを使用した動的検索の作成
- 3. Entity Frameworkで使用中のストアドプロシージャのデバッグ
- 4. Entity Framework 4、ASPNET MVC 3のAsyncControllerを使用した動的プロキシ
- 5. Entity Frameworkを使用したASP.Netでのレポートの作成
- 6. Entity Framework - ナビゲーションプロパティの作成と使用
- 7. ストアドプロシージャとEntity Frameworkの
- 8. Entity Frameworkのみストアドプロシージャ
- 9. Entity Frameworkを使用したWebAPI2が自動的にトランザクションを作成しないのはなぜですか?
- 10. RavenDB - ORフィルタを使用した動的クエリの作成
- 11. Entity FrameworkストアドプロシージャとPOCO
- 12. ストアドプロシージャと組み合わせたEntity Frameworkクエリのサーバー側実行
- 13. ストアドプロシージャのMVC3 Entity FrameworkのVARBINARY
- 14. Entity Framework - ストアドプロシージャの戻り値
- 15. Entity Frameworkを使用した一時的なエンティティ
- 16. ASP.NET、MVC、およびEntity Frameworkを使用した汎用編集ビューの作成
- 17. Entity Framework 4.1を使用して履歴テーブルを作成する
- 18. Entity Frameworkを使用したデータレイヤのデカップリング
- 19. Entity Frameworkを使用したDBContextのジェネリック
- 20. Entity Framework - ナビゲーションプロパティを作成
- 21. Entity Frameworkのオーバーライド動作
- 22. Entity FrameworkまたはEnterprise Libraryを使用してカスタムレポートを作成しますか?
- 23. は、私が使用して動的な型を作成するメソッドを持つEntity Frameworkのコンテキストに
- 24. Entity Framework 5を使用した作業単位と汎用リポジトリ
- 25. Entity Frameworkを使用したレポートサービス
- 26. Entity Frameworkアップデートを使用したTPL
- 27. Entity Frameworkを使用したSpatial MySQL
- 28. SSISとEntity Frameworkを使用したDLL
- 29. Entity Frameworkを使用したwcfデータサービス
- 30. PostgresqlとNpgsqlを使用したEntity Framework