CREATE SYNC MATERIALIZED VIEW
デスクリプション
同期マテリアライズドビューを作成するためのステートメントです。
Syntax
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_PRIV | Table | 現在のマテリアライズドビューのベースTableに対するALTER_PRIV権限が必要 |
注意事項
- 同期マテリアライズドビューは単一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,
l_partkey,
count(*),
sum(l_discount)
FROM
lineitem
GROUP BY
l_shipdate,
l_partkey;