問題を見つける コンテンツをリストで表示すると、リスト内のコンテンツの数は多いかもしれませんが、ユーザーが一度に表示されるインターフェースのサイズは限られているため、必然的にページングの問題が発生します。 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 の落とし穴の詳細な説明
注: この記事のすべての写真はインターネットから収集されたものであるため、DELL R720 サーバ...
Nginx を使用して同じドメイン名で複数のプロジェクトを構成するには、次の 2 つの方法があります...
外部結合の構文は次のとおりです。フィールド名を選択FROM テーブル名 1 LEFT|RIGHT|F...
前回の記事でMySQLサービスが起動しない問題が解決したと分かった後、パスワードなしでrootユーザ...
前回の記事では、Docker を使用して、コンパイルされた jar パッケージをイメージに組み込む ...
AWS - Amazon のクラウド コンピューティング サービス プラットフォーム以前、AWS の...
更新: 最近、サーバーがマイニング ウイルスによってハッキングされたことが判明しました。これは、おそ...
rpmインストールパッケージを使用してmysqlをオフラインでインストールします。参考までに準備:公...
Supervisor は非常に優れたデーモン管理ツールです。自動起動、ログ出力、自動ログカットなど、...
JS のクラスの定義や継承は本当に多様なので、別のノートブックを開いて記録しておきます。意味オブジェ...
ミラーを探すDocker Hubのウェブサイトからイメージを検索できます。Docker Hubのウェ...
これは見落とされがちな問題かもしれません。まず、次の点を明確にする必要があります。 MySQL では...
これら 2 つの属性はよく使用されますが、その違いはまとめられていません。それでは、その使い方をまと...
1. はじめにフロントエンドページのアニメーション効果を記述する場合、filter 属性は多かれ少な...
目次 はじめに 同期 非同期とブロッキング JavaScript のノンブロッキング コールバック ...