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 インストール チュートリアル図 (中国語グラフィカル モード)
>>: ミニプログラム開発ツールのソースコードからの基本実装の分析
または、インストールプロセスを自分で書き留めてください。私のサーバーシステムはAliyun Linu...
目次1. イベントの流れ1. コンセプト2. DOMイベントフロー2. イベントの委任1. イベント...
序文scp は secure copy の略です。scp は、Linux システムの ssh ログイ...
デプロイされるプロジェクトが増えるにつれて、Tomcat にデプロイされるリリース パッケージも増え...
ssh に入り、次のコマンドを入力してパスワードをリセットします (コマンドの末尾の「testpas...
証明書チェーンを生成するスクリプトを使用して、ルート証明書、中間証明書、および 3 つのクライアント...
バージョン番号を非表示バージョン番号は非表示になっていません。セキュリティを強化するために、バージョ...
最近何かをするときにラベル タグを使用しました。以前はラベル タグをほとんど使用していなかったため、...
1. はじめにtr はテキストの一部を変換または削除するために使用されます。 tr は transl...
Vim は Linux でよく使用されるテキスト エディターです。 Vim は、Sublime や ...
Vue2.0/3.0双方向データバインディングの実装原理双方向データバインディングとは、データの変更...
<br />1年前、インターネット上にはinline-blockプロパティに関する記事は...
MySQL 8.0.12 のインストールには 2 日かかり、さまざまな問題が発生しました。以下にまと...
みなさんこんにちは。私は梁旭です。 Linux を使用するときに、計算を行う必要がある場合があり、そ...
まず、ハードディスクデバイスにデータディスクがあるかどうかを確認します # まずfdisk -lを実...