ストアド プロシージャを使用して MySQL 結果セットをループするにはどうすればよいですか?

Linda Hamilton
リリース: 2024-11-19 00:42:02
オリジナル
965 人が閲覧しました

How Can I Loop Over MySQL Result Sets Using Stored Procedures?

MySQL での結果セットのループ: プロシージャベースのアプローチ

プログラマーは、多くの場合、MySQL クエリの結果をループで処理する必要があります。このタスクは通常、PHP の mysql_fetch_assoc 関数、または他のプログラミング言語の同様のメソッドを使用して実行されます。ただし、クエリの結果をループするストアド プロシージャを MySQL で作成することもできます。

これを実現するには、次のようなストアド プロシージャ テンプレートを使用できます:

CREATE PROCEDURE GetFilteredData()
BEGIN
  DECLARE bDone INT;

  DECLARE var1 CHAR(16); 
  DECLARE var2 INT;
  DECLARE var3 VARCHAR(50);
  
  DECLARE curs CURSOR FOR SELECT something FROM somewhere WHERE some stuff;
  DECLARE CONTINUE HANDLER FOR NOT FOUND SET bDone = 1;

  DROP TEMPORARY TABLE IF EXISTS tblResults;
  CREATE TEMPORARY TABLE IF NOT EXISTS tblResults  (
    Fld1 type,
    Fld2 type,
    ...
  );

  OPEN curs;

  SET bDone = 0;
  REPEAT
    FETCH curs INTO var1, var2, var3;

    IF whatever_filtering_desired
       INSERT INTO tblResults VALUES (var1, var2, var3);
    END IF;
  UNTIL bDone END REPEAT;

  CLOSE curs;
  SELECT * FROM tblResults;
END
ログイン後にコピー

考慮事項:

  • クエリ、特に検索条件をパラメータ化することをお勧めします。ストアド プロシージャの柔軟性が向上します。
  • 一時テーブル名が一意になるように、マルチセッション シナリオでセッション ID を渡すことを検討してください。
  • カーソルは結果をループするための手続き型アプローチを提供しますが、その使用方法は次のとおりです。不必要またはパフォーマンスを制限します。純粋に宣言的な SQL ソリューションを検討することをお勧めします。

以上がストアド プロシージャを使用して MySQL 結果セットをループするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート