「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > MySQL から合計数とページ分割された結果の両方を効率的に取得するにはどうすればよいですか?

MySQL から合計数とページ分割された結果の両方を効率的に取得するにはどうすればよいですか?

2024 年 12 月 21 日に公開
ブラウズ:820

How Can I Efficiently Retrieve Both Total Count and Paginated Results from MySQL?

MySQL ページネーション: 結果と合計数の効率的な取得

MySQL でページネーションを実装する場合、2 つの別々のクエリを実行するのが一般的です。結果の合計数を取得するものと、フェッチされたレコードを制限するものがあります。二重クエリとして知られるこのアプローチは、大規模なデータセットでは非効率的になる可能性があります。

ただし、単一のクエリで合計結果数の取得と結果の制限の両方を取得できるかどうかという疑問が生じます。これを直接達成する方法はありませんが、次の 2 つの代替方法が利用可能です:

SQL_CALC_FOUND_ROWS および FOUND_ROWS()

二重クエリの代わりに、SQL_CALC_FOUND_ROWS を利用できます。および FOUND_ROWS() 関数を使用すると、同様の結果が得られます。 SQL_CALC_FOUND_ROWS を含むクエリは制限クエリの前にあり、FOUND_ROWS() 呼び出しは合計数を取得します。

例:

SELECT SQL_CALC_FOUND_ROWS * FROM `table` WHERE `some_condition`;
SELECT FOUND_ROWS();

注: このメソッドには潜在的な欠点があります。 MySQL には、この手法を使用すると ORDER BY クエリに影響を与えるバグがあり、大きなテーブルでは速度が低下します。

カウントのキャッシュ

別の解決策には、合計カウントのキャッシュが含まれます。特定の期間。このアプローチにより、効率を維持しながらカウントを取得するための別のクエリが不要になります。

例:

カウントを取得し、10 分間キャッシュします:

SET @count = (SELECT COUNT(*) FROM `table` WHERE `some_condition`);

後続のクエリでは、キャッシュされたカウントを使用します:

SELECT * FROM `table` WHERE `some_condition` LIMIT 0, 10;

カウントのキャッシュ特に頻繁にアクセスするページのパフォーマンスが大幅に向上します。これは単一クエリのソリューションではありませんが、二重クエリより効率的でありながら同じ結果が得られます。

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

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

Copyright© 2022 湘ICP备2022001581号-3