MySQLのパフォーマンスは、インデックスを使用して説明し、説明します
キーポイント
- MySQLの
EXPLAIN
コマンドを使用して、クエリ実行計画を分析および最適化し、接続タイプやインデックス使用量などの重要な情報を表示することにより、より効率的なデータベース操作を保証します。
クエリ分析を実装してクエリの実際の実行時間を測定し、それにより、ターゲットを絞った最適化を実行して、実行時間を短縮し、全体的なパフォーマンスを改善します。 - コマンドからのフィードバックに基づいて適切なインデックスを追加し、
EXPLAIN
句で使用される列に焦点を当て、データの取得を高速化し、クエリパフォーマンスを改善します。WHERE
検索操作に伴う列の場合、特にクエリで - オペレーターを使用する場合は、フルテキストインデックスを使用してパフォーマンスを最適化することを検討してください。
LIKE
特にインデックスが効果的に使用されていない場合は、結果を制限する結果のパフォーマンスの利点を相殺する可能性があるため、 - と組み合わせて使用することに注意してください。
ORDER BY
LIMIT
データベース最適化は、通常、アプリケーションのパフォーマンスと最も一般的なボトルネックの改善における主要な焦点です。何が必要なのかを測定して理解する方法は?
シンプルで効果的なツールはクエリ分析です。分析を有効にすることで、クエリの実行時間のより正確な推定値が可能になります。これは2段階のプロセスです。最初に、分析を有効にします。
データベースに次の挿入操作が存在すると仮定します(およびユーザー1とギャラリー1が作成されていると仮定します):show profiles
少量のデータは問題を引き起こしませんが、簡単な分析に使用できます。次のクエリを検討してください
INSERT INTO `homestead`.`images` (`id`, `gallery_id`, `original_filename`, `filename`, `description`) VALUES (1, 1, 'me.jpg', 'me.jpg', 'A photo of me walking down the street'), (2, 1, 'dog.jpg', 'dog.jpg', 'A photo of my dog on the street'), (3, 1, 'cat.jpg', 'cat.jpg', 'A photo of my cat walking down the street'), (4, 1, 'purr.jpg', 'purr.jpg', 'A photo of my cat purring');
このクエリの正確な実行時間を取得するには、次のSQLを使用できます。
SELECT * FROM `homestead`.`images` AS i WHERE i.description LIKE '%street%';
show profiles;
コマンドは、元のクエリの時間だけでなく、他のすべてのクエリの時間も表示されるため、クエリを正確に分析できるようにします。
クエリを改善する方法は?
SQLの知識に頼って改善するか、MySQLのEXPLAIN
コマンドに依存して、実際の情報に基づいてクエリパフォーマンスを改善できます。
EXPLAIN
は、クエリ実行計画を取得するために使用されます。つまり、MySQLがクエリを実行する方法です。これは、オプティマイザーによるステートメント実行計画に関する情報とSELECT
、DELETE
、INSERT
、REPLACE
> UPDATE
>>>>>>>>> <公式のドキュメントでは、EXPLAIN
どのように
EXPLAIN
では、インデックスを使用して行を使用して行を見つけることでステートメントがより速く実行できるように、インデックスを追加するテーブルを確認できます。また、EXPLAIN
を使用して、オプティマイザーがテーブルに最適な順序で結合しているかどうかを確認することもできます。
EXPLAIN
の使用を説明するための例を示すために、クエリを使用してユーザーメールをUserManager.php
:
INSERT INTO `homestead`.`images` (`id`, `gallery_id`, `original_filename`, `filename`, `description`) VALUES (1, 1, 'me.jpg', 'me.jpg', 'A photo of me walking down the street'), (2, 1, 'dog.jpg', 'dog.jpg', 'A photo of my dog on the street'), (3, 1, 'cat.jpg', 'cat.jpg', 'A photo of my cat walking down the street'), (4, 1, 'purr.jpg', 'purr.jpg', 'A photo of my cat purring');
EXPLAIN
コマンドを使用するには、SELECT
タイプクエリの前に追加するだけです:
SELECT * FROM `homestead`.`images` AS i WHERE i.description LIKE '%street%';
結果は次のとおりです(すべてを見るために右スクロール):
id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
---|---|---|---|---|---|---|---|---|---|---|---|
1 | SIMPLE | users | NULL | const | UNIQ_1483A5E9E7927C74 | UNIQ_1483A5E9E7927C74 | 182 | const | 1 | 100.00 | NULL |
これらの結果は最初に理解するのが簡単ではありません。それぞれを詳しく見てみましょう。
id
:これは、各クエリのシーケンシャル識別子です。SELECT
- :
select_type
クエリのタイプ。このフィールドは複数の異なる値をとることができるため、最も重要な値に焦点を当てます:SELECT
- :サブクエリや組合のない簡単なクエリ
SIMPLE
- :
PRIMARY
接続の最も外側のクエリにありますselect
- :
DERIVED
は中性子クエリの一部select
ですfrom
:subqueryの最初の<
SUBQUERY
:select
は、連合の2番目またはその後の声明です。 フィールド値の完全なリストはこちらにあります。 -
UNION
select
select_type
:行で参照されるテーブル。
- :サブクエリや組合のない簡単なクエリ
- :このフィールドは、MySQL接続で使用されるテーブルのタイプを表します。これはおそらく、
table
出力で最も重要な分野です。欠落しているインデックスを示したり、クエリがどのようにオーバーライドされたりするかを示すことができます。このフィールドの可能な値は次のとおりです(ベストから最悪のタイプから最悪のタイプまで並べ替えられます): type
:テーブルにはゼロ行または1列があります。EXPLAIN
- :テーブルには行に一致する行が1つだけで、行がインデックス付けされています。これが最速の接続タイプです。
system
- :インデックスのすべての部分は結合で使用され、インデックスは
const
または です。 -
eq_ref
PRIMARY_KEY
:前のテーブルからの各行の組み合わせについて、インデックス列のすべての一致する行が読み取られます。このタイプの結合は通常、UNIQUE NOT NULL
または演算子を使用して比較されたインデックス付き列で発生します。 ref
:テーブルの全文インデックスに参加します。=
- :
fulltext
と同じですが、列の 値からの行も含まれています。 -
ref_or_null
ref
:接続はインデックスリストを使用して結果セットを生成します。NULL
の列には、使用されるキーが含まれます。 index_merge
:EXPLAIN
subqueryは、テーブルから1つの結果のみを返し、主キーを使用します。KEY
- :インデックスを使用して、特定の範囲内で一致する行を見つけます。
unique_subquery
IN
:インデックスツリー全体をスキャンして、一致する行を見つけます。 -
range
:テーブル全体をスキャンして、結合の一致する行を見つけます。これは最悪のタイプの結合であり、通常、テーブルに適切なインデックスが欠落していることを示します。 -
index
ALL
:MySQLがテーブルから行を見つけるために使用できるキーを表示します。これらのキーは、実際に使用される場合と使用できない場合があります。
:MySQLが実際に使用するインデックスを示します。 MySQLは、常にクエリに使用できる最高のキーを見つけます。複数のテーブルを結合すると、- :テーブルには行に一致する行が1つだけで、行がインデックス付けされています。これが最速の接続タイプです。
- にリストされていないが、より良いキーが見つかる場合があります。
possible_keys
- :クエリオプティマイザーで使用されるインデックスの長さを示します。
keys
possible_keys
: - 列の指定されたインデックスと比較される列または定数を表示します。
rows
:チェックされたレコードの数をリストして出力を生成します。これは非常に重要な指標です。Extra
:他の情報が含まれています。この列のUsing filesort
またはUsing temporary
等価物は、問題のクエリを示している場合があります。
EXPLAIN
出力形式の完全なドキュメントは、公式のMySQLページにあります。
シンプルなクエリに戻る:SIMPLE
タイプの接続を備えたselect
タイプconst
です。これは私たちが持っているかもしれない最高のクエリケースです。しかし、より大きく複雑なクエリが必要な場合はどうなりますか?
アプリケーションモードに戻ると、すべてのギャラリー画像を取得する必要があります。また、説明に「猫」という言葉のある写真のみを含めたいかもしれません。これは間違いなくプロジェクトの要件で見つけることができる状況です。クエリを見てみましょう:
INSERT INTO `homestead`.`images` (`id`, `gallery_id`, `original_filename`, `filename`, `description`) VALUES (1, 1, 'me.jpg', 'me.jpg', 'A photo of me walking down the street'), (2, 1, 'dog.jpg', 'dog.jpg', 'A photo of my dog on the street'), (3, 1, 'cat.jpg', 'cat.jpg', 'A photo of my cat walking down the street'), (4, 1, 'purr.jpg', 'purr.jpg', 'A photo of my cat purring');
でより多くの情報を取得する必要があります。
EXPLAIN
SELECT * FROM `homestead`.`images` AS i WHERE i.description LIKE '%street%';
詳細を確認して、クエリで何を改善できるか見てみましょう。
前述のように、最初に表示する必要があるメイン列は、列とtype
列です。目標は、rows
列でより良い値を取得し、type
列の値を最小化することです。 rows
であり、これはまったく良い結果ではありません。これは、私たちがそれを改善できるかもしれないことを意味します。 index
テーブルは使用されません。クエリを拡張して、ユーザーをターゲットにしていることを確認するか、クエリのユーザー部分を完全に削除する必要があります。全体的なパフォーマンスの複雑さと時間を増やすだけです。 Users
INSERT INTO `homestead`.`images` (`id`, `gallery_id`, `original_filename`, `filename`, `description`) VALUES (1, 1, 'me.jpg', 'me.jpg', 'A photo of me walking down the street'), (2, 1, 'dog.jpg', 'dog.jpg', 'A photo of my dog on the street'), (3, 1, 'cat.jpg', 'cat.jpg', 'A photo of my cat walking down the street'), (4, 1, 'purr.jpg', 'purr.jpg', 'A photo of my cat purring');
:EXPLAIN
私たちに残されているのはALL
タイプです。 ALL
はおそらく最悪の種類の接続ですが、それが唯一のオプションである場合があります。要件に応じて、すべてのギャラリー画像が必要なため、galleries
テーブル全体を検索する必要があります。テーブル内のすべての情報が必要な場合、テーブル内で特定の情報を見つけようとすると、インデックスが優れていますが、それらは私たちを助けません。この状況に遭遇したとき、キャッシュなどの他の方法に頼らなければなりません。
LIKE
に取り組んでいるため、最後に改善できるのは、description
フィールドに全文インデックスを追加することです。このようにして、LIKE
をmatch()
に変更し、パフォーマンスを向上させることができます。フルテキストインデックスの詳細については、こちらをご覧ください。
上記は関連ギャラリーです。
INSERT INTO `homestead`.`images` (`id`, `gallery_id`, `original_filename`, `filename`, `description`) VALUES (1, 1, 'me.jpg', 'me.jpg', 'A photo of me walking down the street'), (2, 1, 'dog.jpg', 'dog.jpg', 'A photo of my dog on the street'), (3, 1, 'cat.jpg', 'cat.jpg', 'A photo of my cat walking down the street'), (4, 1, 'purr.jpg', 'purr.jpg', 'A photo of my cat purring');
上記は最新のギャラリーです。
SELECT * FROM `homestead`.`images` AS i WHERE i.description LIKE '%street%';
一見すると、これらのクエリは
を使用するため、非常に高速でなければなりません。これは、ほとんどのクエリでを使用している場合です。残念ながら、当社と当社のアプリケーションにとって、これらのクエリはLIMIT
も使用しています。クエリを制限する前にすべての結果を並べ替える必要があるため、LIMIT
を使用するという利点が失われます。 ORDER BY
LIMIT
を適用しましょう。 ORDER BY
EXPLAIN
id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
---|---|---|---|---|---|---|---|---|---|---|---|
1 | SIMPLE | gal | NULL | ALL | IDX_F70E6EB7A76ED395 | NULL | NULL | NULL | 1 | 100.00 | Using where; Using filesort |
1 | SIMPLE | u | NULL | eq_ref | PRIMARY,UNIQ_1483A5E9BF396750 | PRIMARY | 108 | homestead.gal.id | 1 | 100.00 | NULL |
両方のクエリで、最悪の接続タイプがあることを見ることができます:ALL
。
歴史的に、MySQLの実装は、特にORDER BY
で使用される場合、MySQLのパフォーマンスの問題の原因でした。この組み合わせは、大規模なデータセットを備えたほとんどのインタラクティブなアプリケーションでも使用されています。新しい登録ユーザーや人気のあるタグなどの機能は、この組み合わせをよく使用します。 LIMIT
- インデックスを使用していることを確認してください。私たちの場合、それは私たちが並べ替えている分野であるため、
- は良い候補です。このようにして、完全な結果セットをスキャンしてソートすることなく、
created_at
およびORDER BY
を行うことができます。LIMIT
主要なテーブルの列で並べ替えます。一般に、 - が結合順序の最初のテーブルではないフィールドでソートされている場合、インデックスは使用できません。
ORDER BY
式でソートしないでください。式と関数では、 - がインデックスを使用することはできません。
ORDER BY
- の大きな値に注意を払ってください。大規模な値は、より多くの行を並べ替えるように強制されます。これはパフォーマンスに影響します。
LIMIT
LIMIT
ORDER BY
と
LIMIT
ORDER BY
結論
私たちが見たように、は、できるだけ早くクエリの問題を識別するのに非常に役立ちます。私たちのアプリケーションが生産されているときにのみ注目される多くの問題があり、データベースにアクセスするために多くのデータまたは多くの訪問者があります。これらの問題をできるだけ早く検出するために
を使用できる場合、将来のパフォーマンスの問題の可能性ははるかに小さくなります。
EXPLAIN
アプリケーションには必要なすべてのインデックスがあり、高速ですが、パフォーマンスの向上を確認する必要があるときはいつでも、いつでもEXPLAIN
とインデックスに頼ることができることがわかります。
EXPLAIN
に関するFAQ
データベースパフォーマンスを最適化するには、MySQLパフォーマンスインデックスが重要です。インデックス付き列の値に基づいて、データテーブルの行に迅速にアクセスすることにより、データ検索操作を大幅に高速化します。インデックスがなければ、MySQLは、特に大きなデータベースでは、非常に時間がかかる可能性のある関連する行を見つけるために、テーブル内のすべての行を通過する必要があります。
説明コマンドはMySQLのパフォーマンスを改善するのにどのように役立ちますか?mysqlの
コマンドは、mysqlがクエリを実行する方法に関する情報を提供する強力なツールです。読み取りテーブルの順序、実行される読み取り操作のタイプ、選択できるインデックス、およびチェックする行の推定数を示します。この情報は、開発者がクエリを最適化し、データベースのパフォーマンスを改善するのに役立ちます。
なぜMySQLが可能なキーを使用しないのですか?
MySQLは、いくつかの理由で可能なキーを使用しません。理由の1つは、オプティマイザーがインデックスを使用するにはテーブルのほとんどのスキャンが必要であり、テーブルスキャンがより速くなると判断することを推定することです。もう1つの理由は、WHERE
句の列がインデックスの列と一致しないためかもしれません。
mysqlクエリを最適化する方法は?
mysqlクエリを最適化する方法はいくつかあります。 1つの方法は、インデックスを効果的に使用することです。インデックスは、データの取得を大幅に高速化できます。ただし、INSERT
、UPDATE
、DELETE
などのデータ変更操作が遅くなります。したがって、バランスポイントを見つけることが非常に重要です。もう1つの方法は、EXPLAIN
コマンドを使用して、MySQLがクエリを実行し、潜在的なボトルネックを見つける方法を理解することです。
mysqlの主要なキーとインデックスの違いは何ですか?
MySQLの主キーはインデックスです。主キーは、テーブル内の行の一意の識別子です。列または列の組み合わせの一意性を強制し、列または列の組み合わせにNULL
値が含まれていないことを保証します。一方、インデックスは、データ検索操作の速度を上げることができるデータ構造です。列または列の組み合わせに適用できます。
mysqlでインデックスを作成する方法は?
CREATE INDEX
ステートメントを使用して、MySQLにインデックスを作成できます。構文は次のとおりです。これにより、指定されたテーブルの指定された列にインデックスが作成されます。 CREATE INDEX index_name ON table_name (column1, column2, …);
マルチコラムインデックスとも呼ばれる
複合インデックスは、複数の列を含むインデックスです。 MySQLでは、複合インデックスには最大16列を含めることができますが、インデックス付き列の合計サイズは767バイトを超えることはできません。mysqlでインデックスを削除する方法は?
ステートメントを使用して、MySQLのインデックスを削除できます。構文は次のとおりです。これにより、指定されたテーブルから指定されたインデックスが削除されます。 DROP INDEX
DROP INDEX index_name ON table_name;
MySQLのクラスターインデックスと非クラスター化されたインデックスの違いは何ですか?
クラスターインデックスは、テーブル内のデータの物理的順序を決定します。各テーブルには、クラスター化されたインデックスが1つしかありません。一方、非クラスター化されたインデックスは、テーブル内のデータの物理的順序を変更しません。代わりに、データの行を指す個別のデータ構造(インデックス)を維持し、データの取得を速くすることができます。
mysqlで使用するインデックスを選択する方法は?
MySQLは、コストベースのオプティマイザーを使用して、使用するインデックスを選択します。オプティマイザーは、さまざまなクエリの計画を実行するコストを推定し、最低コストの計画を選択します。コストは、読み取る行数、ディスク検索数、CPUコスト、メモリ使用量などの要因に基づいて推定されます。
以上がMySQLのパフォーマンスは、インデックスを使用して説明し、説明しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHPには4つの主要なエラータイプがあります。1。notice:わずかなものは、未定義の変数へのアクセスなど、プログラムを中断しません。 2。警告:通知よりも深刻で、ファイルを含むなど、プログラムを終了しません。 3。ファタラー:最も深刻なのは、機能を呼び出すなど、プログラムを終了します。 4。ParseError:構文エラーは、エンドタグの追加を忘れるなど、プログラムの実行を防ぎます。

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。

Phpoopでは、self ::は現在のクラスを指し、親::は親クラスを指し、静的::は後期静的結合に使用されます。 1.Self ::静的方法と一定の呼び出しに使用されますが、後期静的結合をサポートしていません。 2.Parent ::サブクラスには、親クラスのメソッドを呼び出すために使用され、プライベートメソッドにアクセスできません。 3.Static ::継承と多型に適した後期静的結合をサポートしますが、コードの読みやすさに影響を与える可能性があります。
