MySQLでクエリキャッシュを実行する方法と失敗を解決する方法

MySQLでクエリキャッシュを実行する方法と失敗を解決する方法

関数を使用する前にパラメータのプロパティを理解して、関数の使い方をより深く理解する必要があることは誰もが知っています。クエリ キャッシュについて学習した後、実際の操作の次のステップに直接進む友人もいます。ここで編集者は、操作を開始する前にパラメータを設定する必要があることを全員に思い出させたいと思います。そうしないと、問題が発生します。 MySQL クエリ キャッシュの手順とキャッシュ無効化の分析を詳しく見てみましょう。

1. 構成パラメータ

(1) have_query_cacheはクエリキャッシュがサポートされているかどうかを示します。YESはサポートを示します

(2)query_cache_typeはキャッシュタイプを示します。OFFはクエリキャッシュをオフにすることを意味し、ONはクエリキャッシュをオンにすることを意味し、DEMANDはユーザー定義のクエリキャッシュを意味します。

(3)query_cache_limitは、単一のクエリSQL文でサポートされるデータの最大量を示します。

(4)query_cache_min_res_unitはクエリキャッシュの最小単位を示す

(5)query_cache_sizeはクエリキャッシュスペースのサイズを示す

(6) query_cache_wlock_invalidateは、クエリキャッシュが書き込みロックをサポートしているかどうかを示します。OFFはサポートしていないことを意味し、データの読み取りでは書き込みロックは考慮されません。ONはサポートしていることを意味し、データの読み取りは書き込みロックによってブロックされます。

MySQL のクエリ キャッシュはデフォルトで無効になっています。クエリ キャッシュを有効にするには、パラメータ クエリ キャッシュ タイプを手動で構成する必要があります。クエリ キャッシュ タイプ パラメータには、次の 3 つの値を指定できます。

1) OFF または 0: クエリ キャッシュ機能は無効です。

2) ON または 1: クエリ キャッシュ機能がオンになります。SELECT 結果は、キャッシュ条件を満たす場合にキャッシュされます。それ以外の場合はキャッシュされません。SQL_NO_CACHE が指定されている場合は、キャッシュされません。

3) DEMAND または 2: クエリ キャッシュ機能は要求に応じて実行されます。SQL_CACHE を明示的に指定する SELECT ステートメントのみがキャッシュされ、その他はキャッシュされません。

/usr/my.cnf 設定に次の設定を追加します。

2. MySQLクエリキャッシュを有効にする

クエリキャッシュタイプ=1

設定が完了したら、サービスを再起動して有効にします。

次に、コマンドラインで SQL ステートメントを実行して検証します。時間のかかる SQL ステートメントを実行し、それを複数回実行して、それ以降の実行時間を確認します。クエリ キャッシュのキャッシュ ヒット数を取得して、クエリ キャッシュを使用するかどうかを判断します。

クエリキャッシュの使用

(1) 同じ文字列等価性を持つクエリSQL文のみが同じキャッシュを使用します。つまり、select name from cityとSELECT name FROM cityは同じキャッシュを使用しません。

(2) query_cache_type が ON の場合、すべてのクエリはデフォルトでキャッシュを使用します。sql_no_cache を使用すると、クエリがキャッシュを使用しないことを明示的に指定できます。

cityからsql_no_cache名を選択します。

(3) query_cache_typeがDEMANDの場合、sql_cacheを使用してクエリがキャッシュを使用することを指定する必要があります。

cityからsql_cache名を選択します。

3. キャッシュの無効化:

テーブルの構造またはデータが変更されると、クエリ キャッシュ内のデータは有効ではなくなります。 INSERT、UPDATE、DELETE、TRUNCATE、ALTER TABLE、DROP TABLE、DROP DATABASE などの操作を行うと、キャッシュされたデータが無効になります。したがって、クエリ キャッシュは、多数の同一クエリを実行するアプリケーションには適していますが、大量のデータ更新を実行するアプリケーションには適していません。

テーブル データのいずれかの行が変更されると、テーブルに関連するすべてのキャッシュが直ちに無効になります。

上記は、MySQL でクエリ キャッシュを実行するために必要な手順です。パラメータ設定についてもう一度おさらいしておきたいと思います。キャッシュが無効な場合は心配せず、エディターの分析に従って解決策を探してください。

以下もご興味があるかもしれません:
  • MySQLクエリキャッシュに関するヒント
  • MySQL クエリ キャッシュとバッファ プール
  • MySQLクエリキャッシュメカニズムの基礎学習チュートリアル
  • MySQLクエリキャッシュをクリアする方法
  • MySQLクエリキャッシュの説明
  • mysql クエリ キャッシュの設定

<<:  Kylin V10 への zabbix-agent のインストール手順

>>:  相対幅を使用してテーブルのサイズを変更する際の問題

推薦する

proxy_pass を設定した後に Nginx が 404 を返す問題を解決する

目次1. proxy_pass を設定した後に Nginx が 404 を返す問題のトラブルシューテ...

SQL文のパフォーマンスを分析するための標準的な要約

この記事では、explain を使用して SQL ステートメントを分析する方法を紹介します。実際、イ...

TCPパフォーマンスチューニングの実装原理とプロセス分析

3ウェイハンドシェイクフェーズクライアントSYNパケットの再試行回数sysctl -w net.ip...

AIX マウント NFS の書き込み効率が低い場合の解決策

NFSが提供するサービスマウント: サーバー上で /usr/sbin/rpc.mountd サーボ ...

Webpack5-react スキャフォールディングをゼロから構築するための実装手順 (ソースコード付き)

目次ウェブパック5公式スタート建築ガイド構築を開始する依存する準備が完了したら、プロジェクトの構築を...

Vueは画像のズームとドラッグをサポートするリッチテキストエディタを統合しています

必要:ビジネス要件によると、写真をアップロードできる必要があり、アップロードされた写真はモバイル端末...

ウェブタイポグラフィにおける致命的な意味的ミス 10 選

<br />これは、Steven D が書いた Web フロントエンド開発デザインの基本...

Vueプロジェクトでのトークン検証ログイン(フロントエンド部分)

この記事の例では、Vueプロジェクトでのトークン検証ログインの具体的なコードを参考までに共有していま...

Mac インストール mysqlclient プロセス分析

仮想環境で pip 経由でインストールしてみてください: pip で mysqlclient をイン...

FastApi+Vue+LayUIを使用してフロントエンドとバックエンドを分離するサンプルコード

目次序文プロジェクト設計後部フロントエンドプロジェクトを実行する質疑応答序文これまでの API 開発...

花火効果を実現するJavaScript(オブジェクト指向)

この記事では、花火効果を実現するためのJavaScriptの具体的なコードを参考までに紹介します。具...

Vuex データの永続性を実装するためのアイデアとコード

vuexとはvuex: vue.js専用に開発された状態管理ツールで、すべてのコンポーネントの状態を...

MySQL 匿名ログインでデータベースを作成できない問題の解決方法

よくある質問ユーザー ''@'localhost' によるデータベー...

Flex プログラム Firefox で中国語を入力すると文字化けするバグ

Firefox の下位バージョンでは中国語の文字を入力できず、上位バージョンでは文字化けした文字が表...