InnoDB テーブルの BLOB 列と TEXT 列のストレージ効率を最適化します。

InnoDB テーブルの BLOB 列と TEXT 列のストレージ効率を最適化します。

まず、MySQL InnoDB エンジンのストレージ形式に関する重要なポイントをいくつか紹介します。

1. InnoDB では、共有テーブルスペースまたは独立テーブルスペースを選択できます。管理とメンテナンスを容易にするために、独立テーブルスペースを使用することをお勧めします。 innodb_file_per_tableオプションを有効にします。5.5 以降では、このオプションをオンラインで動的に変更して有効にし、 ALTER TABLE xx ENGINE = InnoDBを実行して既存のテーブルを独立したテーブルスペースに変換できます。5.5 より前のバージョンでは、このオプションを変更した後、有効にするには再起動する必要があります。

2. InnoDB データ ページのデフォルト サイズは 16KB です。バージョン 5.6 以降では、新しいオプションinnodb_page_sizeを変更できます。バージョン 5.6 より前では、ソース コードを変更して再コンパイルすることしかできません。ただし、この構成のメリットとデメリットを十分に理解していない限り、この構成を変更することはお勧めしません。

3. InnoDB データ ページに新しいデータが書き込まれると、スペースの 1/16 が予約されます。予約されたスペースは、その後の新しいレコードの書き込みに使用できるため、新しいデータ ページを頻繁に追加することによるオーバーヘッドが削減されます。

4. 各データ ページには少なくとも 2 行のレコードを格納する必要があります。したがって、行レコードの最大長は理論上は 8 KB ですが、格納する InnoDB 内部データ構造がいくつかあるため、実際にはこれより小さくなります。

5. InnoDB のストレージ方式の制限により、データが順次書き込まれる場合、データ ページの理想的な充填率は 15/16 ですが、完全な順次書き込みを保証することは通常不可能です。そのため、データ ページの充填率は一般的に 1/2 から 15/16 になります。したがって、新しいレコードをできるだけ順番に書き込めるように、各 InnoDB テーブルに自動インクリメント列を主キーとして設定するのが最適です。

6. データ ページの充填率が 1/2 未満になると、InnoDB はそれを縮小して空き領域を解放します。

7. MySQL 5.6 の InnoDB エンジンは現在、 COMPACTREDUNDANTDYNAMICCOMPRESSED 4 つの形式をサポートしています。デフォルトの形式は COMPACT です。 COMPRESSED はほとんど使用されておらず、推奨されません (次の項目を参照)。圧縮機能を使用する必要がある場合は、TokuDB エンジンを直接検討できます。

8. COMPACT 行形式では、REDUNDANT と比較して約 20% のストレージ スペースを節約でき、COMPRESSED では COMPACT と比較して約 50% のストレージ スペースを節約できますが、TPS は 90% 低下します。したがって、COMPRESSED 行形式の使用は強く推奨されません。

9. 行形式が DYNAMIC または COMPRESSED の場合、TEXT/BLOB などの長い列 (特定の状況によっては、必ずしも TEXT/BLOB 型だけでなく、他の長い列である場合もある長い列) は独立したデータ ページに完全に保存され、クラスター化インデックス ページは新しいページを指すために 20 バイトのポインターのみを使用します。これはいわゆるオフページであり、ORACLE の行移行に似ていますが、大量のディスク領域を浪費し、I/O パフォーマンスが低下します。したがって、長さが 255 を超える BLOB、TEXT、または VARCHAR 列タイプを使用しないことを強くお勧めします。

10. InnoDB ファイル形式 ( innodb_file_format ) が Antelope に設定され、行形式が COMPACT または REDUNDANT の場合、BLOB、TEXT、または長い VARCHAR 列には、クラスター化インデックス ページの最初の 768 バイトのみが格納されます (最大 768 バイトは、プレフィックス インデックスの作成を容易にするために使用されます)。残りのコンテンツは、1 バイトだけ多い場合でも、追加のページに格納されます。したがって、すべての列の長さは可能な限り短くする必要があります。

11. オフページに格納されている BLOB、TEXT、または long VARCHAR 列のページは排他的であり、共有できません。したがって、テーブル内で複数の長い列を使用することは強くお勧めしません。

要約すると、実際のビジネスで InnoDB テーブルに BLOB、TEXT、または長い VARCHAR 列を保存する必要がある場合は、次の提案があります。

1. 複数のオフページを回避するために、すべてのデータをシリアル化して圧縮し、同じ列に保存するようにしてください。

2. 実際の最大格納長が 255 未満の列をVARCHAR型またはCHAR型に変換します (可変長データの場合は両者に違いはありません。固定長データの場合は CHAR 型を使用します)。

3. すべての列を 1 つの列に統合できない場合は、2 番目の選択肢として、各列の最大長に応じて複数のサブテーブルに分割することができます。オフページの頻度を減らすために、各サブテーブルの合計行長を 8KB 未満にするようにしてください。

4. 上記の提案は、データ ページがデフォルトの 16 KB であるという前提に基づいています。8 KB または他のサイズに変更する場合は、上記の理論に基づいて自分でテストし、最も適切な値を見つけてください。

5. 文字列の長さが 255 未満の場合、CHAR または VARCHAR がストレージに使用されているか、または VARCHAR 列の長さが 255 に定義されているかに関係なく、実際の表スペースは増加しません。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。これについてもっと知りたい場合は、次のリンクをご覧ください。

以下もご興味があるかもしれません:
  • MySQLデータベース移行により、大量のデータを迅速にエクスポートおよびインポートできます
  • MySQL データベースを操作して重複データを削除するシェル スクリプト
  • MySQLデータベースで列を追加、削除、変更する方法
  • MySQLはOracleシーケンスに似たソリューションを実装しています
  • シーケンス関数を実装する MySQL コード
  • ソケット ''/tmp/mysql.sock'' 経由でローカル MySQL に接続できない解決策
  • mysql での rpm インストールの詳細な説明
  • よく使用される MySQL 関数の完全なリスト (分類および要約)
  • MySQLのマスタースレーブ構成を使用して、読み取りと書き込みの分離を実現し、データベースの負荷を軽減します。
  • データベースの読み取りと書き込みの分離のコード構成を実現するmysql+spring+mybatis

<<:  PHP の問題により、Zabbix モニタリングでグラフィカル インターフェイスに中国語の文字化けが発生する問題を解決する方法

>>:  Rx レスポンシブプログラミングについての簡単な説明

推薦する

複数の Docker コンテナが同じポート番号を持たない場合の解決策

背景Dockerでは、同じイメージを使用して4つのコンテナを作成します。ネットワークはブリッジモード...

LinuxシステムにTomcatをインストールし、サービスの起動とシャットダウンを構成する

Linuxシステムでサービスの起動とシャットダウンを構成する1. コマンドcd /etc/init....

システム エラー 1067 のため、MySQL 5.6 解凍バージョン サービスを開始できません

今日午後ずっと私を悩ませたバグを記録する半月前から始めましょう。それから.................

Linux デバイス用ネットワーク ドライバーの紹介

有線ネットワーク: イーサネット 無線ネットワーク: 4G、WiFi、Bluetooth、5G 概要...

時点別のMySQLデータベース復旧実績

はじめに: 時間ポイントによる MySQL データベースの復旧どの企業にとっても、データは最も価値の...

Docker ケース分析: Redis サービスの構築

目次1 マウントディレクトリとファイルを作成する2 Redisイメージを取得する3 コンテナを作成し...

特定の MySQL テーブルの完全データと増分データをメッセージ キューに同期する - ソリューション

目次1. 当初の需要2. 解決策3. 運河の導入と設置運河の仕組み建築インストール4. 検証1. 当...

要素の読み込み効果を実現するための純粋なHTML+CSS

これは Element UI の読み込みコンポーネントのエフェクトです。かっこいいですね。実装してみ...

Centos7.x での Nginx のインストール、SSL 設定、一般的なコマンドの詳細な説明

1. インストールyumを使用してインストールする ##yum nginx を自動的にインストールす...

HTML 5 スタイルシートのリセット

この CSS リセットは、Eric Meyers の CSS リセットに基づいて変更されており、特に...

CSS3 を使用して色付きのプログレスバーアニメーションを実装する例

簡単なチュートリアルこれは CSS3 カラー プログレス バー アニメーション効果です。 CSS3 ...

ファイルのダウンロードを実現する javascript Blob オブジェクト

目次例示する1. ブロブオブジェクト2. フロントエンド3. バックエンド要約する例示する最近、ファ...

ES6 配列のコピーおよびフィルメソッド copyWithin() および fill() の具体的な使用法

目次バッチコピー copyWithin()配列を埋めるメソッド fill()指数の計算方法については...

MySQLのファジークエリの要約

1. 一般的な使用法: (1)%で使用する% は 1 つ以上の文字のワイルドカードを表します。たとえ...

MySQL count(1)、count(*)、count(field)の違い

目次1. COUNTの初見2. COUNT(フィールド)、COUNT(定数)、COUNT(*)の違い...