ホームページ >バックエンド開発 >C++ >Entity Framework 6.1.1 のストアド プロシージャからデータを取得する方法

Entity Framework 6.1.1 のストアド プロシージャからデータを取得する方法

DDD
DDDオリジナル
2024-12-29 18:39:10206ブラウズ

How to Retrieve Data from Stored Procedures in Entity Framework 6.1.1?

Entity Framework のストアド プロシージャからデータを取得する

Entity Framework 6.1.1 を使用して動的 SQL ストアド プロシージャを操作する場合、データを取得することができます。挑戦です。一般的なシナリオは、ストアド プロシージャからのデータを使用して GridView コントロールにデータを設定しようとしますが、空の結果セットによる例外が発生することです。

この問題を解決するには、ストアド プロシージャを関数としてインポートする必要があります。エンティティモデル。次の手順に従います。

  1. エンティティ モデルのワークスペース領域を右クリックし、追加 -> を選択します。 関数インポート.
  2. 関数インポートの追加ダイアログで、次を指定します:

    • 名前: モデル内のストアド プロシージャの参照名。例: "Search_Products".
    • 関数: 動的 SQL ストアド プロシージャを選択します。
    • 戻り値: [エンティティ] を選択し、[製品] を選択します。返されるエンティティ タイプ。
  3. コード ビハインド:

    var db = new MyEntities();
    var TEST_SEARCH_TERM = "product";
    var result = db.Search_Products(TEST_SEARCH_TERM); // Search_Products is the name you specified in the Function Import dialog
    
    MyGridView.DataSource = result;
    MyGridView.DataBind();

ストアド プロシージャを関数としてインポートすることにより、Entity Framework は戻り値の型を決定し、それを適切なエンティティにマップできます。これにより、ストアド プロシージャの SELECT ステートメントからのオブジェクトを含む IEnumerable DataSet が結果として得られ、GridView に正常にデータを設定できるようになります。

Entity Framework はストアド プロシージャを広範にサポートしていないことに注意することが重要です。 ORM としての焦点が異なり、ストアド プロシージャの戻り値を処理する機能は、使用される Entity Framework のバージョンによって異なる場合があります。

以上がEntity Framework 6.1.1 のストアド プロシージャからデータを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。