検索
ホームページデータベースmysql チュートリアルMySQL のクエリ キャッシュに関する基本的な知識は何ですか?

クエリキャッシュとは何ですか?

MySQL クエリ キャッシュは、MySQL 5.7 で非推奨になりました (8.0 では削除されました) が、以前に実行されたステートメントをメモリに保存します。つまり、クエリ キャッシュは通常、データベースのメモリ中央に SELECT ステートメントを保存します。したがって、クエリを実行し、しばらくしてからまったく同じクエリを再度実行すると、結果はディスクからではなくメモリから取得されるため、より速く返されます。

クエリ キャッシュはクエリと結果セットをキャッシュします。したがって、同じクエリを実行すると、クエリのキャッシュされた結果がすぐに返されます。クエリ キャッシュ サイズは、query_cache_size システム変数を設定することで制御できますが、次の点に注意してください。クエリでクエリ キャッシュを使用する場合、クエリはバイトごとに同一である必要があります。これは、これら 2 つのクエリをまったく同じ方法でキャッシュする必要があると考えている場合でも、次のことを意味します。 demo_table where column = 'Demo';

実際には、そうではありません。 MySQL クエリ キャッシュですべてのクエリが同一であることが必要な場合、たとえ 1 バイトだけ異なっていても結果は返されません。
つまり、要約すると、MySQL がステートメントを実行するときに最初に行うことは、クエリ キャッシュが有効になっているかどうかを確認することです (復習が必要な場合は、遅い MySQL クエリに関する以前のブログの記事に戻ってください。) ) クエリ キャッシュが有効な場合、MySQL はまずクエリに関連する一致があるかどうかを確認し、一致しない場合は次のステップに進みます。重複した一致がある場合、MySQL はクエリ キャッシュから結果を返します。 MySQL 内部クエリ キャッシュ

マッチに戻る前に、MySQL のクエリ キャッシュは MySQL の確認を必要とします。 d OES このユーザーはそのようなアクションを完了するために必要な権限を持っていますか?クエリの実行を拒否する必要がありますか?

MySQL がチェックする権限のリストは次のとおりです:

権限

簡単な説明ALLすべての権限を特定の MySQL ユーザーに付与します。 SELECT特定の MySQL ユーザーに、指定されたデータベースから行を選択する権限を付与します。 UPDATE 特定の MySQL ユーザーに、指定されたテーブル内の既存の行を更新する権限を付与します。 SHOW DATABASES特定の MySQL ユーザーが、特定の MySQL インスタンスに存在するすべての MySQL データベースのリストを取得できるようにします。 USAGEユーザーに MySQL のみを使用する権限を与えます。つまり、ユーザーは MySQL 内でクエリを実行できません。本質的には「特権のない者」と同義。

にはさらに多くの権限がありますが、ご理解いただけたでしょうか。 MySQL はテーブル関連の情報をキャッシュされたクエリとともに保存するため、クエリのキャッシュには権限が重要です。権限は、MySQL の結果チェック プロセスの最初の段階の 1 つであるため、同様に重要です。すべての仕組みは次のとおりです。


優先度の識別

MYSQL STATUS#1MySQL はクエリ キャッシュ内の権限をチェックしています。 まず、MySQL は、特定のユーザーが特定の結果にアクセスする権限を持っているかどうかを確認します。 #5 結果をキャッシュに保存します。 MySQL はクエリ結果をクエリ キャッシュに保存します。 #6

「MySql にはキャッシュがありません!」: クエリ キャッシュが破損しているかどうかによって異なりますか?

クエリで変数を使用すると、関数状態であってもパーティション状態であっても、クエリ キャッシュは無効になります。たとえば、ビッグ データを扱っており、SELECT ... INTO OUTFILE を使用して大規模なデータ セットを MySQL にロードする場合、結果もキャッシュされません。通常、SELECT ... [LOCK | FOR | INTO] のようなクエリを使用する場合、クエリ キャッシュは機能しません。また、NULL 値を持つ列の AUTO_INCREMENT 値をチェックしている場合にもクエリ キャッシュは機能しません。列 AUTO_INCREMENT には増分があり、次のようなクエリを実行します。

SELECT * FROM demo_table WHERE increment IS NULL;

クエリ キャッシュは有効になりません。

おっしゃるとおり、これらの機能はすべて役に立たないと感じる人もいるかもしれません。 MySQL の他の機能と同様、クエリ キャッシュには独自の制限があるため、常に機能するとは限りません。上記に加えて、ステートメントが警告を生成した場合、ステートメントが TEMPORARY ストレージ エンジンを備えたテーブルで実行された場合、およびその他の特殊なケースでは、動作が拒否されます。誰かがテーブルに何かを書き込むたびに、クエリ キャッシュもクリアされます。

クエリ キャッシュの機能は、query_cache_size パラメーターにも依存します。このパラメータは大きいほど良いですが、このパラメータはメモリに大きく依存することに注意してください。クエリ キャッシュの基本構造にはデフォルトで少なくとも 40kB のストレージが必要であり、そのデフォルト値は 1MB ~ 16MB であることに注意してください。データベースがデータを頻繁に読み取る場合は、パラメーター値を増やすと最適な解決策が見つかる可能性がありますが、もう一度実験してください。

「RESET QUERY CACHE」ステートメントを使用すると、クエリ キャッシュ内のすべての内容をクリアできます。 FLUSH TABLES のようなステートメントを使用すると、すべてのクエリ キャッシュ値も削除されます。

MySQL では、クエリを実行することでクエリ キャッシュに保存されているクエリの数を確認することもできます:

SHOW STATUS LIKE 'Qcache_queries_in_cache%';

次のような結果が得られます:

MySQL:

+-------------------------+--------+
| Variable_name           | Value  |
+-------------------------+--------+
| Qcache_queries_in_cache | 1      |
+-------------------------+--------+

この場合、クエリ キャッシュが現在結果をキャッシュしていることがわかります。 FLUSH TABLES のようなステートメントを実行すると、すべての値が消えます。

#2 MySQL はクエリ自体のクエリ キャッシュをチェックしています。 次に、MySQL はクエリ キャッシュに同じクエリが存在するかどうかのチェックを開始します。一致するものがあれば、MySQL は戻りますが、一致しない場合は、MySQL は次のステップに進みます。
3 MySQL はクエリ キャッシュ内のエントリを無効としてマークしました。 テーブルが変更されると、クエリ キャッシュを更新する必要があります。したがって、このステップでは、MySQL はクエリ キャッシュ内のエントリを無効としてマークすることを決定します。
4 結果を送信します。 MySQL はキャッシュされた結果を送信し、表示します。
クエリ キャッシュはロックされています。 これでキャッシュ プロセスが完了しました。MySQL はクエリ キャッシュをロックしました。

以上がMySQL のクエリ キャッシュに関する基本的な知識は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
MySQL Index Cardinalityはクエリパフォーマンスにどのように影響しますか?MySQL Index Cardinalityはクエリパフォーマンスにどのように影響しますか?Apr 14, 2025 am 12:18 AM

MySQLインデックスのカーディナリティは、クエリパフォーマンスに大きな影響を及ぼします。1。高いカーディナリティインデックスは、データ範囲をより効果的に狭め、クエリ効率を向上させることができます。 2。低カーディナリティインデックスは、完全なテーブルスキャンにつながり、クエリのパフォーマンスを削減する可能性があります。 3。ジョイントインデックスでは、クエリを最適化するために、高いカーディナリティシーケンスを前に配置する必要があります。

MySQL:新規ユーザー向けのリソースとチュートリアルMySQL:新規ユーザー向けのリソースとチュートリアルApr 14, 2025 am 12:16 AM

MySQL学習パスには、基本的な知識、コアの概念、使用例、最適化手法が含まれます。 1)テーブル、行、列、SQLクエリなどの基本概念を理解します。 2)MySQLの定義、作業原則、および利点を学びます。 3)インデックスやストアドプロシージャなどの基本的なCRUD操作と高度な使用法をマスターします。 4)インデックスの合理的な使用や最適化クエリなど、一般的なエラーのデバッグとパフォーマンス最適化の提案に精通しています。これらの手順を通じて、MySQLの使用と最適化を完全に把握できます。

実際のmysql:例とユースケース実際のmysql:例とユースケースApr 14, 2025 am 12:15 AM

MySQLの実際のアプリケーションには、基本的なデータベース設計と複雑なクエリの最適化が含まれます。 1)基本的な使用法:ユーザー情報の挿入、クエリ、更新、削除など、ユーザーデータの保存と管理に使用されます。 2)高度な使用法:eコマースプラットフォームの注文や在庫管理など、複雑なビジネスロジックを処理します。 3)パフォーマンスの最適化:インデックス、パーティションテーブル、クエリキャッシュを使用して合理的にパフォーマンスを向上させます。

MySQLのSQLコマンド:実用的な例MySQLのSQLコマンド:実用的な例Apr 14, 2025 am 12:09 AM

MySQLのSQLコマンドは、DDL、DML、DQL、DCLなどのカテゴリに分割でき、データベースとテーブルの作成、変更、削除、データの挿入、更新、削除、複雑なクエリ操作の実行に使用できます。 1.基本的な使用には、作成可能な作成テーブル、INSERTINTO INSERTデータ、クエリデータの選択が含まれます。 2。高度な使用法には、テーブル結合、サブQueries、およびデータ集約のためのグループに参加します。 3.構文エラー、データ型の不一致、許可の問題などの一般的なエラーは、構文チェック、データ型変換、許可管理を介してデバッグできます。 4.パフォーマンス最適化の提案には、インデックスの使用、フルテーブルスキャンの回避、参加操作の最適化、およびデータの一貫性を確保するためのトランザクションの使用が含まれます。

InnoDBは酸コンプライアンスをどのように処理しますか?InnoDBは酸コンプライアンスをどのように処理しますか?Apr 14, 2025 am 12:03 AM

INNODBは、ロックメカニズムとMVCCを通じて、非論的、一貫性、および分離を通じて原子性を達成し、レッドログを介した持続性を達成します。 1)原子性:Undologを使用して元のデータを記録して、トランザクションをロールバックできることを確認します。 2)一貫性:行レベルのロックとMVCCを介してデータの一貫性を確保します。 3)分離:複数の分離レベルをサポートし、デフォルトでrepeatable -readが使用されます。 4)持続性:Redologを使用して修正を記録し、データが長時間保存されるようにします。

MySQLの場所:データベースとプログラミングMySQLの場所:データベースとプログラミングApr 13, 2025 am 12:18 AM

データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

MySQL:中小企業から大企業までMySQL:中小企業から大企業までApr 13, 2025 am 12:17 AM

MySQLは、中小企業に適しています。 1)中小企業は、顧客情報の保存など、基本的なデータ管理にMySQLを使用できます。 2)大企業はMySQLを使用して、大規模なデータと複雑なビジネスロジックを処理して、クエリのパフォーマンスとトランザクション処理を最適化できます。

Phantomの読み取りとは何ですか?Innodbはどのようにそれらを防ぐ(次のキーロック)?Phantomの読み取りとは何ですか?Innodbはどのようにそれらを防ぐ(次のキーロック)?Apr 13, 2025 am 12:16 AM

INNODBは、次のキーロックメカニズムを通じてファントムの読み取りを効果的に防止します。 1)Next-KeyLockingは、Row LockとGap Lockを組み合わせてレコードとギャップをロックして、新しいレコードが挿入されないようにします。 2)実際のアプリケーションでは、クエリを最適化して分離レベルを調整することにより、ロック競争を削減し、並行性パフォーマンスを改善できます。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。