MySQLの制限を使用して大規模なページングの問題を解決する方法

MySQLの制限を使用して大規模なページングの問題を解決する方法

序文

日常の開発では、MySQL を使用してページングを実装する場合、常に MySQL 制限構文を使用します。ただし、その使用方法は非常に特殊なので、今日はそれをまとめてみましょう。

制限構文

limit 構文は、offset と limit の 2 つのパラメータをサポートします。前者はオフセットを示し、後者は最初の limit データを取得することを示します。

例えば:

## 条件を満たす最初の10個のステートメントを返す select * from user limit 10

## 条件を満たす11番目から20番目のデータを返す select * from user limit 10,20

上記から、限界 n は限界 0,n と同等であることもわかります。

パフォーマンス分析

実際の使用では、ページングの後ろにある一部のページの読み込みが遅くなることがわかります。つまり、次のようになります。

ユーザー制限 1000000,10 から * を選択

ステートメントの実行は遅いです。まずはテストしてみましょう。

まず、小さなオフセットで 100 個のデータを取得します (データの総量は約 200 個)。その後、オフセットを徐々に増やします。

select * from user limit 0,100 ---------時間消費 0.03秒
select * from user limit 10000,100 ---------時間消費 0.05秒
select * from user limit 100000,100 ---------時間消費 0.13秒
select * from user limit 500000,100 ---------時間消費 0.23秒
select * from user limit 1000000,100 ---------時間消費 0.50秒
select * from user limit 1800000,100 ---------時間消費 0.98秒

オフセットが増加するにつれて、パフォーマンスがどんどん悪化していくことがわかります。

なぜでしょうか? limit 10000,10 の構文は、実際には MySQL がデータの最初の 10010 行を見つけ、最初の 10000 行を破棄することを意味しているためです。このステップは実際には無駄です。

最適化

IDで最適化

まず、最後のページングの最大 ID を見つけ、次に、select * from user where id>1000000 limit 100 と同様に、ID のインデックスを使用してクエリを実行します。
これは主キーがインデックス化されるため非常に効率的ですが、ID が連続している必要があり、where ステートメントによってデータがフィルター処理されるためクエリに where ステートメントを含めることができないという欠点があります。

カバーインデックスによる最適化

MySQL クエリがインデックスに完全にヒットすると、カバーリング インデックスと呼ばれます。これは、クエリがインデックスを検索するだけで済み、データを取得するためにデータ テーブルに戻ることなく直接戻ることができるため、非常に高速です。したがって、最初にインデックス ID を見つけてから、その ID に基づいてデータを取得できます。

select * from (select id from job limit 1000000,100) a left join job b on a.id = b.id;

これには0.2秒かかりました。

要約する

確かに、MySQL を使用して大量のデータをページ分割するのは困難ですが、最適化する方法はいくつかあり、ビジネス シナリオと組み合わせてさらにテストを行う必要があります。
ユーザーが 10,000 ページに移動したときに、空を返さないのはなぜですか? それはそんなに退屈ですか?

さて、今回の記事は以上です。この記事の内容が皆さんの勉強や仕事に少しでも参考になれば幸いです。123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL クエリの最適化: LIMIT 1 はテーブル全体のスキャンを回避し、クエリの効率を向上させます
  • 制限を使用すると、MySQL のページングがどんどん遅くなるのはなぜですか?
  • MySQL 最適化 query_cache_limit パラメータの説明
  • MySQLのorder byとlimitを混在させる際の落とし穴の詳細な説明
  • MySQL ページングの制限パラメータの簡単な例
  • 大きなオフセットによる MySQL 制限ページングが遅い理由と最適化ソリューション
  • MySQL のソートとページング (order by と limit) と既存の落とし穴
  • MySQL における制限関数と合計関数の混在使用の問題の詳細な説明
  • MySQL Limitクエリのパフォーマンスを向上させる方法
  • MySQL Limitパフォーマンス最適化とページングデータパフォーマンス最適化の詳細な説明
  • MySQL の制限ページング最適化ソリューションの実装に関する簡単な説明
  • MySQL のクエリパフォーマンスに対する制限の影響

<<:  Linux bash: ./xxx: バイナリ ファイルを実行できません エラー

>>:  Reactでaxiosを使用してリクエストを送信する一般的な方法

ブログ    

推薦する

この記事では、6つの負荷分散技術の実装方法をまとめます(要約)

ロード バランシングは、サーバー クラスタの展開でよく使用されるデバイスです。マシンのパフォーマンス...

Alibaba Cloud Server Tomcatにアクセスできません

目次1. はじめに2. 解決策2.1 ファイアウォールを設定してポートを開く2.3 ポートを確認し、...

Linux システム MySQL8.0.19 クイックインストールと構成チュートリアル図

目次1. 環境の紹介2. MySQL-8.0.19をインストールする3. MySQLを設定する1. ...

Vue が Bibibili のホームページを模倣する際の問題

エンジニアリング構造プロジェクトは2つの部分に分かれています。bilibili-apiはAPIインタ...

LinuxはNetworkManagerを使用してMACアドレスをランダムに生成します

今では、自宅のソファーに座っていても、外の喫茶店にいても、ノートパソコンの電源を入れてWi-Fiに接...

element-uiのアップロードコンポーネントでファイルやその他のパラメータを転送する際の問題を分析する

最近、element-ui を統合したプロジェクトで vuethink を使用しました。以前は bo...

Centos7 FFmpeg オーディオ/ビデオ ツールのインストールに関する簡単なドキュメント

ffmpeg は非常に強力なオーディオおよびビデオ処理ツールです。公式 Web サイトは http:...

Docker と Intellij IDEA の融合により、Java 開発の生産性が 10 倍向上

目次1. 開発前の準備2. 新しいプロジェクトIdea は Java 開発のための強力なツールであり...

dockerネットワーク双方向接続の詳細な説明

Dockerネットワークを見るdocker ネットワーク ls [root@master ~]# d...

MySQL のタイムスタンプと日付時刻のタイムゾーンの問題によって生じる DTS の落とし穴の詳細な説明

目次MySQL で現在の時刻を表現するにはどうすればよいでしょうか?結論は確認するピットMySQL ...

JSX を使用してコンポーネント パーサー開発を構築する例

目次JSX環境の構築プロジェクトの設定NPMを初期化するwebpackをインストールするBabelを...

カルーセル効果を実現するための純粋なjs

この記事では、カルーセルマップの効果を実現するためのjsの具体的なコードを参考までに共有します。具体...

MySQL NULLがピットを引き起こした

比較演算子でNULLを使用する mysql> 1>NULLを選択します。 +------...

Docker コンテナ ソース コードのデプロイ httpd ストレージ ボリュームを使用して Web サイトをデプロイする (推奨)

目次Dockerコンテナのソースコードを使用してhttpdをデプロイし、ストレージボリュームを使用し...

Linux カーネル デバイス ドライバー proc ファイル システム ノート

/***************** * proc ファイルシステム***************...