問題を見つける コンテンツをリストで表示すると、リスト内のコンテンツの数は多いかもしれませんが、ユーザーが一度に表示されるインターフェースのサイズは限られているため、必然的にページングの問題が発生します。 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 の落とし穴の詳細な説明
問題を見つける今日、Docker コンテナ内のファイルを変更しようとしたところ、コンテナ内に vim...
marquee タグを使用してフォントのスクロールを設定したいです。コードは次のように記述しましたが...
序文テーブルを削除するには、無意識に思い浮かぶコマンドは、DROP TABLE "テーブル...
参考までに、Winでmysql5.7をインストールします。具体的な内容は次のとおりです。 @Auth...
DTD はマークアップの文法規則のセットです。これは XML 1.0 仕様の一部であり、HTML フ...
最近のビジネスでは、オンライン トレーニング システムが特定のオンライン プレビュー ページに対する...
序文そこでこのブログを書きました。このブログでは大物の記事からいくつかの知識も推奨しています。侵害が...
目次序文事例: JD.com の虫眼鏡効果の模倣オフセットシリーズクライアントシリーズスクロールシリ...
アプリケーションをコンテナ化した後、Docker コンテナを起動すると、デフォルトで root ユー...
序文:日々の勉強や仕事の中で、データをエクスポートする必要に迫られることがよくあります。たとえば、デ...
目次序文1. 需要と効果必要効果2. コードの実装index.vue(html)日付方法テスト結果3...
目次1.1. MySQL binlog を有効にする1.2. RabbitMQ の交換とキューを構成...
目次ナンセンス実装された機能文章要点ナンセンスデモプレビュー実装された機能デフォルトでホームページが...
Windows 2008 Serverのサブドメインを親ドメインに参加させると、「ドメインは既に存...
Docker の使用に関するヒント1. 停止したDockerコンテナをすべてクリーンアップする停止し...