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

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_PRIVTable現在のマテリアライズドビューのベース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;