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); 以下もご興味があるかもしれません:
|
<<: Centos8 システムの VMware インストール チュートリアル図 (中国語グラフィカル モード)
>>: ミニプログラム開発ツールのソースコードからの基本実装の分析
MySQL データベースにとって binlog バイナリ ログがどれほど重要であるかについては詳し...
目次MySQL 削除構文エイリアスの問題mysql の delete ステートメントでエイリアスを使...
目次1. 画像のバイナリデータを表示する方法2. 絵の種類の見分け方3. 画像の種類を検出する方法3...
序文誰もが vue2 の watch API に精通している必要があります。vue2 の vue イ...
結果から判断すると、タイトルを定義するための固定パターンはなく、すべてむしろランダムな感じがします。...
HTML の一般的なコメント: <!--XXXXXXXX--> (XXXXXXXX はコ...
1. Nginxのインストール手順1.1 公式サイトの紹介http://nginx.org/en/d...
序文最近CocosCreatorを学びたいと思ったので、エディターをダウンロードして起動しました。誰...
序文プロジェクトのニーズにより、ストレージ フィールドは JSON 形式で保存されます。プロジェクト...
Docker を使用すると、外部からコンテナにアクセスしたり、コンテナを相互接続したりすることで、ネ...
Linuxでシェルスクリプトを共有して、MySQLのマスタースレーブ状態を監視し、エンタープライズW...
この記事は「Attribution 4.0 International (CC BY 4.0)」ライ...
Oracle データベースから MySQL データベースへの移行では、Oracle データベース モ...
# 以下の例は x64 ビット ランタイム v3.0.0 用です mkdir /runtimes ...
目次CSS カスタム変数機能は古くから存在していますが、実際の開発ではあまり使用されていません。その...