ウェブサイトやサービスのパフォーマンスは、データベースの設計(適切な言語開発フレームワークを選択した場合)とデータのクエリ方法に大きく依存します。 MySQL のパフォーマンス最適化方法を理解しています。これには通常、インデックスの作成、複雑な結合クエリの回避、冗長フィールドの設定、中間テーブルの作成、クエリ キャッシュなどが含まれます。また、EXPLAIN を使用して実行プランを表示する方法も理解しています。 しかし、複雑な MySQL クエリ ステートメントの実行プロセスと内部メカニズム、MySQL Optimizer 自体によって行われる最適化、クエリ ステートメントの調整がパフォーマンスに与える影響とその原因についてはほとんどわかっていません。 この記事では、実行プロセスやインデックスの使用法など、いくつかの重要な概念についてさらに詳しく説明し、その理由を理解しようとします。 これにより、単純な MySQL 最適化で良好な結果が得られる場合に、盲目的に NoSQL ストレージに切り替えたり、インフラストラクチャのアップグレードに投資したりする必要がなくなります。 仕事をうまくやり遂げたいなら、まずツールを磨かなければなりません。ここではまず、MySQL クエリ ステートメントのパフォーマンス分析ツールを紹介します。 MySQL の EXPLAIN コマンドは、クエリのパフォーマンスを分析するためのツールです。EXPLAIN の出力の各行は、クエリ ステートメント内のテーブルの実行プランの説明に対応します。出力列の意味は次のとおりです。 上記の表の「タイプ」列は、テーブルの関連付けのタイプです。一般的なタイプは次のとおりです (関連付けクエリの効率の高い順に並べています)。
キー列はインデックスを表し、行はスキャンされる行の推定数を表します。 Extra は追加情報を示します。一般的なものは次のとおりです (これもクエリ効率の降順で並べられています)。
EXPLAIN に次の 2 つのメッセージ (Using filesort、Using temporary) が表示され、行が比較的大きい場合は、通常、クエリ ステートメントを調整するか、インデックスを追加する必要があることを意味します。つまり、これら 2 つのメッセージを排除する必要があります。 以下は EXPLAIN 結果の例です (ユーザー プロファイル テーブルからニックネームと性別を検索し、ユーザー テーブル内のユーザー フォロワーの数で並べ替えます)。 上記のクエリ ステートメントは、典型的な問題の例です。filesort の使用と temporary の使用の具体的な意味、および上記のステートメントを最適化する方法については、クエリ プロセスと原則と併せて次の記事で説明します。 以上がこの記事の全内容です。お役に立てれば幸いです。他にご質問がございましたら、メッセージを残してご連絡ください。 引き続き 123WORDPRESS.COM にご注目ください。 以下もご興味があるかもしれません:
|
<<: NextCloud プライベート クラウド ストレージ ネットワーク ディスクの構築に関する詳細なチュートリアル
>>: vue-cli 設定では Vuex の完全なプロセスレコードを使用します
日々の最適化プロセス中に、奇妙なことに気付きました。同じ SQL にまったく異なる 2 つの実行プラ...
効果確認アドレス:ツアープラン(uplanok.com) コード: img{幅: 100%;境界線の...
JavaScriptをクリックすると画像の形状が変わります(変形の応用)。参考までに具体的な内容は...
1. ノードサーバーのセットアップ + データベース接続ここでの操作は比較的簡単でわかりやすいです。...
目次導入Intel CPUをサポートApple M1のサポートテスト導入このプロジェクトでは最近、P...
フォルダを作成するディレクトリ構造: dabaots npm init -yを初期化して packa...
目次1. ディレクティブカスタムディレクティブ2. ミックスイン3. 継承を拡張する4. 提供して注...
以下は、mysql 5.7 の /etc/my.cnf の一般的なパラメータの一部です。これらを自分...
多くのウェブサイトを閲覧すると、ブラウザのアドレスバーの前に小さなアイコンがあり、ブラウザのタブの位...
Linux での Hadoop インストール チュートリアルはインターネットや書籍に多数ありますが、...
目次uni-app のスタイル要約するuni-app のスタイルsassプラグインは公式ウェブサイト...
JDBC の 6 つのステップ: 1. ドライバーを登録する2. データベース接続を取得する3. デ...
目次1. Antデザインビュー1. 公式ウェブサイトアドレス2. 使い方3.電子書籍テーブルを表示す...
IDEA は Java で最も一般的に使用されている開発ツールであり、Docker は最も人気のある...
カルーセルを作りたい場合、まずその原理を理解する必要があります。画像を右から左にスライドさせるにはど...