問題を見つける コンテンツをリストで表示すると、リスト内のコンテンツの数は多いかもしれませんが、ユーザーが一度に表示されるインターフェースのサイズは限られているため、必然的にページングの問題が発生します。 1 つのインターフェースにすべてのコンテンツを表示することは不可能です。 バックエンドから一度に取得するデータが多すぎると、バックエンドに余分な負荷がかかります。 通常、ページング クエリには次のステートメントが使用されます。 選択 * テーブルから 条件1 = 0の場合 条件2 = 0 条件3 = -1 条件4 = -1 ID昇順で並べ替え 制限 2000 オフセット 50000 オフセットが特に大きい場合、このステートメントの実行効率は大幅に低下し、オフセットが増加するにつれて効率は低下します。 理由は次のとおりです。 MySQL はオフセット行をスキップせず、オフセット + N 行を取得し、前のオフセット行を返して N 行を返します。オフセットが特に大きく、単一のデータも大きい場合、クエリを実行するたびに取得する必要があるデータが多くなり、速度が低下します。 最適化計画: 選択 * テーブルから 参加する (テーブルからIDを選択 条件1 = 0の場合 条件2 = 0 条件3 = -1 条件4 = -1 ID昇順で並べ替え 制限 2000 オフセット 50000) tmp として (id) を使用 または テーブルaからa.*を選択します。 (テーブルからIDを選択 条件1 = 0の場合 条件2 = 0 条件3 = -1 条件4 = -1 ID昇順で並べ替え 制限 2000 オフセット 50000) b ここで、a.id = b.id まず主キーリストを取得し、次に主キーで対象データを照会します。オフセットが大きい場合でも、すべてのフィールドデータではなく、多くの主キーが取得されます。相対的に効率が大幅に向上します。 要約する 上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に少しでもお役に立てれば幸いです。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただき、ありがとうございます。 以下もご興味があるかもしれません:
|
<<: Reactの親コンポーネントと子コンポーネント間のデータ転送の詳細な説明
>>: nginx 設定チュートリアルにおける add_header の落とし穴の詳細な説明
目次1.0 はじめに2.0 Dockerのインストール3.0基本的なDockerコマンド4.0 Do...
1. docker設定ファイルを変更し、ポート2375を開きます。 [root@s162 docke...
一緒に学びましょう1. 伝統的な方法コードをコピーコードは次のとおりです。 <object c...
HTML 開発の歴史: HTML は英語で Hypertext Marked Language の...
1. プロキシサーバーとは何ですか?プロキシ サーバーは、クライアントが要求を送信すると、それを直接...
Dockerfile を使用すると、ユーザーはカスタム イメージを作成できます。基本構造Docker...
目次1. 学習目標1.1. Tomcatアーキテクチャの設計と原則をマスターして社内スキルを向上させ...
この記事は主に、Vue のレスポンシブ ソース コードを理解していない、または触れたことがない人向け...
iframe の src を 'about:blank' に設定した後、"...
この記事では、Ubuntu 18.04 に Redis と phpredis 拡張機能をインストール...
目次概要達成方法具体的な実装評価関数の終了を決定する生成関数の範囲変換関数マップフィルター割り込み機...
システムメンテナンス中は、いつでも CPU 使用率を確認し、対応する情報に基づいてシステムの状態を分...
1. 現象早朝、オンライン テーブルにインデックスが追加されました。テーブル内のデータ量が大きすぎた...
序文:一部のアプリケーション シナリオでは、成績や年齢によるランキングなど、ランキングの問題が発生す...
問題の説明今日、ページ スタイルを変更していたときに、子要素にmargin-top設定したのに、子要...