MySQLのMERGEストレージエンジンの詳細な説明

MySQLのMERGEストレージエンジンの詳細な説明

MERGE ストレージ エンジンは、MyISAM テーブルのグループを論理ユニットとして扱い、同時にクエリを実行できるようにします。 MERGE データ テーブル構造を構成する各メンバー MyISAM データ テーブルは、まったく同じテーブル構造を持つ必要があります。各メンバー テーブルの列は同じ名前とタイプで同じ順序で定義する必要があり、インデックスも同じ順序と方法で定義する必要があります。複数のログ データ テーブルがあり、各テーブルに過去数年間の各年のログ エントリが含まれているとします。定義は次のとおりです。YY は年を表します。

テーブル log_YY を作成します ( 
  dt DATETIME NULLではありません、 
  情報 VARCHAR(100) NOT NULL、 
  インデックス(dt) 
)エンジン = MyISAM;

現在のログ データ テーブル セットに log_2004、log_2005、log_2006、および log_2007 が含まれていると仮定します。次に示すように MERGE データ テーブルを作成し、それらを論理単位にグループ化できます。

テーブル log_merge を作成します ( 
  dt DATETIME NULLではありません、 
  情報 VARCHAR(100) NOT NULL、 
  インデックス(dt) 
) ENGINE = MERGE UNION = (log_2004、log_2005、log_2006、log_2007);

ENGINE オプションの値は MERGE である必要があり、UNION オプションには、この MERGE テーブルに含まれる関連テーブルがリストされます。この MERGE が作成されると、他のデータ テーブルと同様にクエリを実行できます。ただし、各クエリは各メンバー データ テーブルに対して同時に実行されます。次のクエリを使用すると、上記のログ データ テーブル内のデータ行の合計数を知ることができます。

log_mergeからCOUNT(*)を選択します。

次のクエリは、各年の各年にログ エントリがいくつあるかを判断するために使用されます。

YEAR(dt) AS y、COUNT(*) AS エントリ FROM log_merge GROUP BY y; を選択します。

MERGE テーブルでは、複数のクエリを発行せずに複数のテーブルを同時に参照することが容易になるだけでなく、次のような利便性も提供されます。

1) MERGE テーブルを使用すると、各 MyISAM テーブルで許可されている最大長を超えるサイズの論理ユニットを作成できます。

2) 圧縮されたデータ テーブルは MERGE データ テーブルに含まれます。たとえば、ある年が過ぎると、対応するログ ファイルにレコードを追加することはなくなるため、myisampack ツールを使用してログ ファイルを圧縮してスペースを節約できます。また、MERGE テーブルは通常どおり機能します。

3) MERGE データ テーブルは、DELETE および UPDATE 操作もサポートします。 INSERT 操作は、MySQL が新しいデータ行をどのメンバー テーブルに挿入するかを知る必要があるため、より面倒です。 MERGE テーブルの定義には、INSERT_METHOD オプションを含めることができます。このオプションの可能な値は NO、FIRST、LAST です。これらはそれぞれ、INSERT 操作が禁止され、新しいデータ行が現在の UNION オプションにリストされている最初のテーブルまたは最後のテーブルに挿入されることを意味します。たとえば、次の定義では、log_merge テーブルに対する INSERT 操作を、UNION オプションにリストされている最後のテーブルである log_2007 テーブルに対する INSERT として扱います。

テーブル log_merge を作成します ( 
  dt DATETIME NULLではありません、 
  情報 VARCHAR(100) NOT NULL、 
  インデックス(dt) 
) ENGINE = MERGE UNION = (log_2004、log_2005、log_2006、log_2007) INSERT_METHOD = LAST;

同じテーブル構造を持つ新しいメンバー テーブル log_2009 を作成し、log_merge テーブルを変更して log_2009 を含めます。log_2009:

CREATE TABLE log_2009 LIKE log_2008; // 古いテーブルに基づいて新しいテーブルを作成します ALTER TABLE log_merge UNION = (log_2004, log_2005, log_2006,log_2007,log_2008,log_2009);

以下もご興味があるかもしれません:
  • MySQL での挿入または更新操作の実装 (Oracle の merge ステートメントに類似)
  • MySQLMerge ストレージ エンジン

<<:  Centos8 システムの VMware インストール チュートリアル図 (中国語グラフィカル モード)

>>:  ミニプログラム開発ツールのソースコードからの基本実装の分析

推薦する

Ubuntu で FTP サーバーを構築する方法の詳細な説明 (成功保証)

1. 今日の午後、コースの要件により、Ubuntu で FTP サーバーを設定する実験を行う必要が...

MySQL 5.7.21 winx64 のインストールと設定方法のグラフィックチュートリアル

この記事では、MySQL 5.7.21のインストールに関する注意事項をまとめ、皆さんと共有します。 ...

Mysqlツリー再帰クエリの実装方法

序文部門テーブルなどのデータベース内のツリー構造データの場合、部門のすべての従属部門または部門のすべ...

tomcatでcatalina.outログをカットする3つの方法の詳細な説明

1. ログセグメンテーションのためのLog4j 1) log4j-1.2.17.jar、tomcat...

MySQL のインデックスの原理とクエリの最適化の詳細な説明

目次1. はじめに1. インデックスとは何ですか? 2. インデックスはなぜ必要なのでしょうか? 2...

jQueryは画像の強調表示を実現します

ページ上の画像を強調表示することは非常に一般的です。ここでは、jQuery を使用して画像を強調表示...

Centos6.5 で MySQL 5.7.19 をインストールして設定する方法

Centos6.5にmysql5.7.19をインストールするための詳細な手順は次のとおりです。 1....

Nginx proxy_redirect の使用方法の詳細な説明

今日、Apache の nginx リバース プロキシを実行していたときに、ちょっとした問題に遭遇し...

Vueはドラッグ可能なツリー構造図を実装します

目次Vue 再帰コンポーネントドラッグイベント最近、Vue を使用して、ドラッグ可能なツリー構造図と...

js のループメソッドとさまざまなトラバーサルメソッド

目次forループwhileループdo-while ループループのネストトラバーサルメソッド~のために...

MySQL での coalesce() の使用に関するヒントのまとめ

序文最近、偶然 MySQL の coalesce を発見しました。ちょうど時間があったので、MySQ...

Pythonの関数知識についての簡単な説明

目次関数パラメータの2つの主要なカテゴリ位置パラメータ可変長パラメータ名前空間要約する関数パラメータ...

MySQL Innodb インデックス メカニズムの詳細な紹介

1. インデックスとは何ですか?インデックスは、ストレージ エンジンがレコードをすばやく検索するため...

Apache Bench で Web ストレス テストを実装する方法

1. Apache Benchの紹介ApacheBench は、Apache サーバーに付属する W...