「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > チャンクを使用して大規模な MySQL 選択を効率的に取得するにはどうすればよいですか?

チャンクを使用して大規模な MySQL 選択を効率的に取得するにはどうすればよいですか?

2024 年 11 月 9 日に公開
ブラウズ:298

How can I efficiently retrieve large MySQL selects by using chunking?

チャンキングを使用して大規模な MySQL 選択を効率的に取得する

MySQL で大規模なデータセットを処理すると、データ取得中にメモリの問題が発生することがよくあります。これを解決するには、チャンキングが効果的な解決策を提供します。

チャンキング手法

チャンキングには、大規模な選択クエリを小さなサブセットに分割することが含まれます。そうすることで、メモリ制限を回避しながら、管理可能な部分でデータを処理できます。

次の例を考えてみましょう:

SELECT * FROM MyTable ORDER BY whatever LIMIT 0,1000;

このクエリは、MyTable から最初の 1,000 行を取得します。次の 1,000 を取得するには、LIMIT オフセットをインクリメントします。

SELECT * FROM MyTable ORDER BY whatever LIMIT 1000,1000;

Maintaining Row Order

行の順序が維持されるようにするには、元のテーブルのスナップショットとして一時テーブルを作成します。

CREATE TEMPORARY TABLE MyChunkedResult AS (
  SELECT *
  FROM MyTable
  ORDER BY whatever
);

この一時テーブルは、結果をチャンクする間、順序付けされたデータを保持します:

SELECT * FROM MyChunkedResult LIMIT 0, 1000;

後続のチャンクの LIMIT オフセットをインクリメントします。 .

考慮事項

  • 反復回数を少なくするには、より大きなチャンク サイズを使用することを検討してください。
  • 特定のデータセットとサーバーに基づいて最適なチャンク サイズを決定しますリソース。
  • チャンク プロセスの完了後に一時テーブルを削除します。

このチャンク手法を実装すると、大規模な MySQL 選択結果をチャンク単位で効果的に取得できるため、メモリの問題が回避され、パフォーマンスが向上します。 .

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3