メインコンテンツまでスキップ
バージョン: 26.x

CREATE SYNC MATERIALIZED VIEW を作成する

説明

同期化されたマテリアライズドビューを作成するためのステートメントです。

構文

CREATE MATERIALIZED VIEW <materialized_view_name> [AS] <query>            

どこで

query
:
SELECT <select_expr> select_expr[, select_expr ...]
FROM <base_table>
WHERE condition
GROUP BY <column_name>[, <column_name> ...]
ORDER BY <column_name>[, <column_name> ...]

必須パラメータ

1. <materialized_view_name>

マテリアライズドビューの識別子(すなわち、名前)を指定します。同期マテリアライズドビューはTableに基づいて作成されるため、名前は同じTable内で一意である必要があります。

識別子は文字で始まる必要があり(Unicode名前サポートが有効な場合、任意の言語の文字を使用可能)、識別子文字列全体をバッククォートで囲まない限り(例:My Object)、スペースや特殊文字を含むことはできません。

識別子は予約キーワードにすることはできません。

詳細については、識別子と予約キーワードの要件を参照してください。

2. <query>

マテリアライズドビューを構築するために使用されるクエリステートメントで、その結果がマテリアライズドビューのデータを構成します。現在サポートされているクエリフォーマットは以下の通りです:

構文はクエリステートメント構文と一致しています。

  • select_expr:マテリアライズドビューのスキーマ内のすべての列。
    • 少なくとも1つの単一列を含む必要があります。
  • base_table:マテリアライズドビューのベースTableの名前、必須項目。
    • サブクエリではなく、単一のTableである必要があります。
  • where:マテリアライズドビューのフィルタ条件、オプション項目。
    • 指定されない場合、データフィルタリングは実行されません。
  • group by:マテリアライズドビューのグループ化列、オプション項目。
    • 指定されない場合、データはグループ化されません。
  • order by:マテリアライズドビューのソート列、オプション項目。
    • ソート列の宣言順序は、select_exprで宣言された列の順序と一致している必要があります。
    • order byが宣言されていない場合、ルールに従ってソート列が自動的に補完されます。マテリアライズドビューが集約タイプの場合、すべてのグループ化列が自動的にソート列として追加されます。マテリアライズドビューが非集約タイプの場合、最初の36バイトが自動的にソート列として追加されます。
    • 自動的に補完されたソート列の数が3未満の場合、最初の3つがソート列として使用されます。クエリにグループ化列が含まれている場合、ソート列はグループ化列と一致している必要があります。

アクセス制御要件

権限オブジェクト備考
ALTER_PRIVTable現在のマテリアライズドビューのベースTableに対するALTER_PRIV権限が必要

注意事項

  • 同期マテリアライズドビューのselectリスト内の列名は、ベースTableの既存の列と同じであってはならず、同じベースTable上の他の同期マテリアライズドビューの列名と重複してもいけません。エイリアスを指定することで名前の競合を回避できます(例:col as xxx)。
  • 同期マテリアライズドビューは単一Tableに対するSELECTステートメントのみをサポートし、WHERE、GROUP BY、ORDER BY句をサポートしますが、JOIN、HAVING、LIMIT句やLATERAL VIEWはサポートしません。
  • SELECTリストには自動インクリメント列、定数、重複する式、またはウィンドウ関数を含めることはできません。
  • SELECTリストに集約関数が含まれている場合、集約関数はルート式である必要があり(例:sum(a + 1)はサポートされますが、sum(a) + 1はサポートされません)、集約関数の後に他の非集約関数式を続けることはできません(例えば、SELECT x, sum(a)は許可されますが、SELECT sum(a), xは許可されません)。
  • 単一Table上のマテリアライズドビューが多すぎると、データインポートの効率に影響を与える可能性があります:データをインポートする際、マテリアライズドビューとBaseTableのデータが同期的に更新されます。Table上にマテリアライズドビューが多すぎる場合、単一のインポート操作で複数のTableに同時にデータをインポートするのと同様に、インポート速度が遅くなる可能性があります。
  • マテリアライズドビューがUnique Keyデータモデルを対象とする場合、列の順序を変更することのみができ、集約を実行することはできません。したがって、Unique Keyモデルでは、マテリアライズドビューを作成してデータを粗く集約することはできません。
  • マテリアライズドビューがUnique KeyおよびAggregate Keyデータモデルを対象とする場合、WHERE句が指定されている場合は、Key列のみを使用でき、Value列は使用できません。

desc lineitem;
+-----------------+---------------+------+-------+---------+-------+
| Field | タイプ | Null | Key | Default | Extra |
+-----------------+---------------+------+-------+---------+-------+
| l_orderkey | int | No | true | NULL | |
| l_partkey | int | No | true | NULL | |
| l_suppkey | int | No | true | NULL | |
| l_linenumber | int | No | true | NULL | |
| l_quantity | decimal(15,2) | No | false | NULL | NONE |
| l_extendedprice | decimal(15,2) | No | false | NULL | NONE |
| l_discount | decimal(15,2) | No | false | NULL | NONE |
| l_tax | decimal(15,2) | No | false | NULL | NONE |
| l_returnflag | char(1) | No | false | NULL | NONE |
| l_linestatus | char(1) | No | false | NULL | NONE |
| l_shipdate | date | No | false | NULL | NONE |
| l_commitdate | date | No | false | NULL | NONE |
| l_receiptdate | date | No | false | NULL | NONE |
| l_shipinstruct | char(25) | No | false | NULL | NONE |
| l_shipmode | char(10) | No | false | NULL | NONE |
| l_comment | varchar(44) | No | false | NULL | NONE |
+-----------------+---------------+------+-------+---------+-------+
CREATE MATERIALIZED VIEW sync_agg_mv AS
SELECT
l_shipdate as shipdate,
l_partkey as partkey,
count(*),
sum(l_discount)
FROM
lineitem
GROUP BY
l_shipdate,
l_partkey;