キーポイント
- 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
:行で参照されるテーブル。
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がテーブルから行を見つけるために使用できるキーを表示します。これらのキーは、実際に使用される場合と使用できない場合があります。
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 サイトの他の関連記事を参照してください。

thedifferencebetferencefued fieneunset()andsession_destroy()isthatunset()clearsspecificsessionvariablesはsessionactiveであり、ssession_destroy()ターミナテンテンセッション

StickysionsionsureuserRequestsoredtotheSameserverforsessiondataconsistency.1)Sessionidedificationisionidificationsisignivisionsignsignsuserstoserversusing okiesorurlmodifications.2)CondingRoutingDirectSSubSubSubsEntRequestStotheSameserver.3)LoadBalancingDistributeNewuser

phpoffersvarioussionsionsavehandlers:1)ファイル:デフォルト、simplebutmaybottleneckonhigh-trafficsites.2)memcached:high-performance、yealforspeed-criticalapplications.3)redis:similartomcached、witordededpersistence.4)データベースの提供

PHPでのセッションは、サーバー側のユーザーデータを保存して、複数のリクエスト間で状態を維持するメカニズムです。具体的には、1)セッションはsession_start()関数によって開始され、データは保存され、$ _Sessionスーパーグローバルアレイを読みます。 2)セッションデータはデフォルトでサーバーの一時ファイルに保存されますが、データベースまたはメモリストレージを介して最適化できます。 3)セッションを使用して、ユーザーのログインステータス追跡とショッピングカート管理機能を実現できます。 4)セッションの安全な送信とパフォーマンスの最適化に注意を払い、アプリケーションのセキュリティと効率を確保します。

phpssionsStartWithsession_start()、figenateAuniqueidandcreateSaServerfile; theySistacrossRequestsandcanbemanbemanBeithsession_destroy()

絶対セッションのタイムアウトはセッションの作成時に開始され、アイドルセッションタイムアウトはユーザーの操作なしに開始されます。絶対セッションタイムアウトは、金融アプリケーションなど、セッションライフサイクルの厳格な制御が必要なシナリオに適しています。アイドルセッションタイムアウトは、ソーシャルメディアなど、ユーザーが長い間セッションをアクティブに保つことを望んでいるアプリケーションに適しています。

サーバーセッションの障害は、手順に従って解決できます。1。セッションが正しく設定されていることを確認するために、サーバーの構成を確認します。 2.クライアントCookieを確認し、ブラウザがそれをサポートしていることを確認し、正しく送信します。 3. Redisなどのセッションストレージサービスを確認して、それらが正常に動作していることを確認します。 4.アプリケーションコードを確認して、正しいセッションロジックを確認します。これらの手順を通じて、会話の問題を効果的に診断および修復し、ユーザーエクスペリエンスを改善することができます。

session_start()iscrucialinphpformangingusersions.1)itInitiateSanewsessionifnoneExists、2)resumesanexistingsession、および3)SetSessionCookieforcontinuityAcrossRequests、ApplicationslicationSliviseSlikeUserauthicationAnticatent。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

WebStorm Mac版
便利なJavaScript開発ツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

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

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
