MariaDB の Information Schema INNODB_BUFFER_PAGE テーブルとは?

2024-04-03

MariaDB の Information Schema INNODB_BUFFER_PAGE テーブルは、InnoDBバッファプール内の各ページに関する情報を提供します。この情報は、InnoDBバッファプールの状態を監視し、パフォーマンスを最適化するのに役立ちます。

テーブル構成

カラム名データ型説明
POOL_IDINTEGERバッファプールのID
BLOCK_IDBIGINTバッファプール内のページのID
PAGE_TYPEVARCHAR(1)ページの種類 ('i' - インデックスページ、'd' - データページ)
SPACE_IDINTEGERテーブルスペースのID
PAGE_NOINTEGERテーブルスペース内のページ番号
HEAP_NOINTEGERヒープ内のページ番号 (データページの場合のみ)
ROW_IDBIGINTページ内の最初の行のID (データページの場合のみ)
MIXED_INDEX_IDINTEGERページに格納されている混合インデックスのID (存在する場合)
INDEX_IDINTEGERページに格納されているインデックスのID (存在する場合)
OLD_BLOCK_IDBIGINTLRUリストの古いブロックのID
LRU_POSITIONINTEGERLRUリスト内のページの位置
FIX_COUNTINTEGERページへの参照カウント
IS_HASHEDINTEGERページがハッシュインデックスにあるかどうか (1 - あり、0 - なし)
ACCESS_TIMETIMESTAMPページへの最後のアクセス時刻
MODIFIEDINTEGERページが変更されたかどうか (1 - 変更あり、0 - 変更なし)
DIRTYINTEGERページがフラッシュされていないかどうか (1 - フラッシュされていない、0 - フラッシュ済み)
BUFFER_PAGE_PTRPOINTERページへのポインター

主な用途

  • InnoDBバッファプールの使用状況を監視する
  • 特定のページに関する情報を取得する
  • パフォーマンスの問題を診断する

  • バッファプール内のすべてのページの情報を見たい場合:
SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE;
  • 特定のページの情報を見たい場合:
SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE
WHERE POOL_ID = 0 AND BLOCK_ID = 12345;
  • バッファプール内の使用されていないページを見たい場合:
SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE
WHERE FIX_COUNT = 0;

注意事項

  • INNODB_BUFFER_PAGE テーブルは、パフォーマンスに影響を与える可能性があるため、慎重に使用してください。
  • このテーブルは、InnoDBの内部構造に依存するため、将来のバージョンで変更される可能性があります。

補足

  • 上記の情報に加えて、INNODB_BUFFER_PAGE テーブルには、パフォーマンス分析に役立つその他の多くのカラムがあります。
  • 詳細については、上記の参考情報をご覧ください。


SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE;

出力例

POOL_ID | BLOCK_ID | PAGE_TYPE | SPACE_ID | PAGE_NO | HEAP_NO | ROW_ID | MIXED_INDEX_ID | INDEX_ID | OLD_BLOCK_ID | LRU_POSITION | FIX_COUNT | IS_HASHED | ACCESS_TIME | MODIFIED | DIRTY | BUFFER_PAGE_PTR
------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | --------
0       | 12345    | i       | 0       | 1       | NULL    | NULL    | NULL     | NULL     | 0        | 10        | 0        | 0        | 2023-11-14 12:34:56 | 0        | 0        | 0x12345678
0       | 12346    | d       | 1       | 2       | 1       | 100     | NULL     | NULL     | 0        | 11        | 1        | 1        | 2023-11-14 12:34:56 | 1        | 1        | 0x12345679
...     | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...      | ...
SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE
WHERE POOL_ID = 0 AND BLOCK_ID = 12345;

出力例

POOL_ID | BLOCK_ID | PAGE_TYPE | SPACE_ID | PAGE_NO | HEAP_NO | ROW_ID | MIXED_INDEX_ID | INDEX_ID | OLD_BLOCK_ID | LRU_POSITION | FIX_COUNT | IS_HASHED | ACCESS_TIME | MODIFIED | DIRTY | BUFFER_PAGE_PTR
------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | --------
0       | 12345    | i       | 0       | 1       | NULL    | NULL    | NULL     | NULL     | 0        | 10        | 0        | 0        | 2023-11-14 12:34:56 | 0        | 0        | 0x12345678
SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE
WHERE FIX_COUNT = 0;

出力例

POOL_ID | BLOCK_ID | PAGE_TYPE | SPACE_ID | PAGE_NO | HEAP_NO | ROW_ID | MIXED_INDEX_ID | INDEX_ID | OLD_BLOCK_ID | LRU_POSITION | FIX_COUNT | IS_HASHED | ACCESS_TIME | MODIFIED | DIRTY | BUFFER_PAGE_PTR
------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | --------
0       | 12347    | d       | 1       | 3       | NULL    | NULL    | NULL     | NULL     | 0        | 20        | 0        | 0        | 2023-11-14 12:34:56 | 0        | 0        | 0x1234567a
0       | 12348    | i       | 0       | 2       | NULL    | NULL    | NULL     | NULL     | 0        | 21        | 0        | 0        | 2023-11-14 12:34:56 | 0        | 0        | 0x1234567b
...     | ...      | ...


MariaDB の INNODB_BUFFER_PAGE テーブルに関するその他情報

  • INNODB_BUFFER_PAGE テーブルの代わりに、SHOW INNODB STATUS コマンドを使用して、バッファプールの情報を取得することができます。
  • mysqldumpslow などのツールを使用して、バッファプールの使用状況に関する詳細情報を取得することができます。
  • 上記の情報は役に立ちましたか?
  • その他ご質問はありますか?



MariaDB の SET データ型:使いこなしてデータ管理を効率化

MariaDB の SET データ型は、複数の値をカンマ区切りで格納できる特殊なデータ型です。選択肢の集合を表す場合などに役立ちます。特徴最大64個の値を格納可能値は 文字列 または 数値格納順序は 保持されない重複した値は 許可されないNULL 値を格納可能



MariaDB INTEGER データ型:プログラミング解説

定義: 符号付き整数値を格納するためのデータ型範囲: -2147483648 から 2147483647 まで (32ビット)デフォルト: 多くの場合、INT は INTEGER のエイリアスとして使用用途: 主に、以下の用途で使用 カウント、ID 番号、数量など、整数値を扱うカラム 外部キー


データベースで文字列を扱う!MariaDBの文字列データ型を徹底解説

MariaDB には、文字列データを格納するために使用できるいくつかのデータ型があります。それぞれのデータ型には、長所と短所があり、使用するデータ型は、格納するデータと、そのデータにどのようにアクセスするかによって異なります。MariaDB における主な文字列データ型は以下の通りです:


MariaDB の Data Types における SET CHARACTER SET の徹底解説

文字コード: 文字をコンピュータ上で表現するための規則。UTF-8、latin1 など様々な種類が存在します。照合順序: 文字列の比較方法を定義。文字コード内でどの文字がどのように並ぶかを決定します。SET CHARACTER SET は、以下の役割を担います。


プログラミングにおける Information Schema REFERENTIAL_CONSTRAINTS テーブルの活用

MariaDB の Information Schema REFERENTIAL_CONSTRAINTS テーブルは、データベース内のすべての参照制約に関するメタ情報を格納します。このテーブルは、データベース構造を理解し、参照制約を管理するのに役立ちます。



MariaDB 10.2 以前のバージョンで JSON 形式で文字列をエスケープする方法

MariaDB の JSON_QUOTE 関数は、文字列を JSON 形式で安全にエスケープするために使用されます。これは、特殊文字や制御文字を含む文字列を、JSON 文書の一部として安全に保存できるようにするためです。構文引数str: エスケープする文字列


MariaDB の SQL 文と構造で LOG10 関数を使いこなす: 豊富なサンプルコード付き

構文:引数:数値: 基数10の対数を求めたい数値戻り値:数値: 基数10の対数例:このクエリは、100 の基数10の対数を求めます。結果は 2 です。これは、100 を 10 の 2 乗で表せるからです。LOG10 関数は、さまざまな用途に使用できます。以下にいくつかの例を示します。


MariaDB INTEGER データ型:プログラミング解説

定義: 符号付き整数値を格納するためのデータ型範囲: -2147483648 から 2147483647 まで (32ビット)デフォルト: 多くの場合、INT は INTEGER のエイリアスとして使用用途: 主に、以下の用途で使用 カウント、ID 番号、数量など、整数値を扱うカラム 外部キー


MariaDB mysql.columns_priv テーブルの操作方法 – サンプルコード付き

mysql. columns_priv テーブルは、MariaDB のデータベースアクセス制御において重要な役割を果たします。このテーブルは、特定のユーザーが特定のデータベース内の特定のテーブルの列に対してどのような権限を持っているかを定義します。


MariaDB の Information Schema FILES テーブル:データベースの奥深くに潜る

テーブル構成活用例特定のファイルサイズを確認特定テーブルスペースのファイル一覧インデックスサイズが大きいファイルの特定古いファイルの削除注意事項INFORMATION_SCHEMA は仮想テーブルであり、直接変更することはできません。削除や更新は、mysqldump などのツールを用いて行いましょう。