1. インデックス不足または無効なインデックスによるクエリの遅延 数千万件のデータを含むテーブルで、インデックスのない列をクエリ条件として使用すると、ほとんどの場合、クエリに非常に時間がかかります。このクエリは間違いなく遅い SQL クエリです。したがって、大量のデータを含むクエリの場合、クエリを最適化するために適切なインデックスを作成する必要があります。 インデックスは頻繁に作成されますが、特定のシナリオでは失敗する可能性があるため、インデックスの失敗もクエリが遅くなる主な原因の 1 つとなります。 2. ロック待機 一般的に使用されるストレージ エンジンには、InnoDB と MyISAM があります。前者は行ロックとテーブル ロックをサポートしますが、後者はテーブル ロックのみをサポートします。 データベース操作がテーブル ロックに基づいて実装されている場合、注文テーブルを更新するときにロックする必要がある場合、他の多数のデータベース操作 (クエリを含む) が待機状態になり、システムの同時実行パフォーマンスに重大な影響を与えることを想像してください。 現時点では、InnoDB ストレージ エンジンでサポートされている行ロックは、同時実行性の高いシナリオに適しています。ただし、InnoDB ストレージ エンジンを使用する場合は、行ロックがテーブル ロックにアップグレードされる可能性に特別な注意を払う必要があります。バッチ更新操作中、行ロックがテーブル ロックにアップグレードされる可能性があります。 MySQL では、テーブルで大量の行ロックを使用すると、トランザクションの実行効率が低下し、他のトランザクションの待機時間が長くなり、ロックの競合が増えて、パフォーマンスが著しく低下する可能性があると考えています。そのため、MySQL では行ロックをテーブル ロックにアップグレードします。さらに、行ロックはインデックスに基づくロックです。更新操作中に条件付きインデックスが失敗した場合、行ロックはテーブル ロックにアップグレードされます。 したがって、テーブル ロックに基づくデータベース操作では、SQL がブロックされて待機状態になり、実行速度に影響します。更新操作 (挿入\更新\削除) が読み取り操作以上になる場合、MySQL では MyISAM ストレージ エンジンの使用は推奨されません。 ロックのアップグレードに加えて、行ロックはテーブルロックに比べて粒度が細かく、同時実行機能が向上していますが、デッドロックという新しい問題も発生します。したがって、行ロックを使用する場合は、デッドロックを回避するように注意してください。 3. 不適切なSQL文 不適切な SQL ステートメントの使用も、SQL が遅くなる最も一般的な原因の 1 つです。たとえば、<SELECT *>、<SELECT COUNT(*)> SQL ステートメントの使用、大規模なデータ テーブルでの <LIMIT M,N> ページング クエリの使用、およびインデックスのないフィールドの並べ替えに慣れています。 以上が今回ご紹介したノウハウポイントの全てです。123WORDPRESS.COMをどうぞよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: VMware Workstation と vSphere 間で仮想マシンを移行する (画像とテキスト)
>>: JavaScript のフラット配列をツリー構造に変換する例
この効果はブラウザ ページで最もよく見られます。まずは効果の画像をご覧ください。 上の図に示すように...
前回の記事では、Vue で画像の切り抜きや拡大・縮小、回転を実現する方法を紹介しました。今回は、アイ...
1. パフォーマンス スキーマ: はじめにMySQL 5.7 では、多数の新しい監視項目の導入、ス...
Windows 10 1903 は、2019 年に Microsoft がリリースした Windo...
序文誰もが vue2 の watch API に精通している必要があります。vue2 の vue イ...
1. MySQLが以前にインストールされていたかどうかを確認するコマンド: rpm -qa|grep...
序文ブロガーはアイデアIDEを使用しています。アイデア公式が最近サードパーティのアクティベーションサ...
障害の説明percona5.6、mysqldump フルバックアップ、バックアップデータのインポート...
今日、リモートデスクトップを実行してログインしているときにこのプロンプトを見つけました「MySQL ...
目次1. nginx とは何ですか? 2. nginx で何ができるのか? 2.1 フォワードプロキ...
目次1.コンポーネントtimelineH.vueを実装する2. コンポーネントの呼び出しこの記事では...
目次1. イメージをプルする2. Redisコンテナを作成する3. コンテナを起動するためにクラスタ...
【はじめに】: Handtrack.jsは、ブラウザ上で直接リアルタイムの手の動きの追跡と検出を実...
最近プロジェクトが中断され、RageFrame の研究は一時的に終了しました。この記事では、シングル...
mysql使用中に接続数が超過していることが判明しました~~~~ [root@linux-node...