非同期マテリアライズドビュー
このトピックでは、非同期マテリアライズドビューの理解、作成、使用、管理方法について説明します。非同期マテリアライズドビューは、StarRocks v2.4以降でサポートされています。
同期マテリアライズドビューと比較して、非同期マテリアライズドビューはマルチテーブルジョインやより多くの集計関数をサポートしています。非同期マテリアライズドビューのリフレッシュは、手動で、事前に指定された間隔で定期的に、またはベーステーブルのデータ変更時に自動的にトリガーされることがあります。また、マテリアライズドビュー全体ではなく、一部のパーティションのみをリフレッシュすることもでき、リフレッシュのコストを大幅に削減できます。さらに、非同期マテリアライズドビューはさまざまなクエリの書き換えシナリオをサポートしており、自動的で透明なクエリアクセラレーションを可能にします。
同期マテリアライズドビュー(Rollup)のシナリオと使用法については、Synchronous materialized view (Rollup)を参照してください。
概要
データベースのアプリケーションでは、大規模なテーブルに対して複雑なクエリを実行することがよくあります。これらのクエリは、数十億行を含むテーブルに対するマルチテーブルジョインや集計を含みます。これらのクエリを処理することは、システムリソースや結果を計算するのにかかる時間の観点から高コストです。
StarRocksの非同期マテリアライズドビューは、これらの問題に対処するために設計されています。非同期マテリアライズドビューは、1つまたは複数のベーステーブルから事前に計算されたクエリ結果を保持する特別な物理テーブルです。ベーステーブルに対して複雑なクエリを実行すると、StarRocksはこれらのクエリを処理するために関連するマテリアライズドビューから事前に計算された結果を返します。この方法により、繰り返しの複雑な計算を避けることでクエリパフォーマンスが向上します。このパフォーマンスの違いは、クエリが頻繁に実行される場合や十分に複雑な場合に顕著です。
さらに、非同期マテリアライズドビューは、データウェアハウス上に数学モデルを構築するのに特に役立ちます。これにより、上位層のアプリケーションに統一されたデータ仕様を提供し、基盤の実装を隠したり、ベーステーブルの生データのセキュリティを保護したりできます。
StarRocksにおけるマテリアライズドビューの理解
StarRocks v2.3以前のバージョンでは、単一のテーブルにのみ構築できる同期マテリアライズドビューが提供されていました。同期マテリアライズドビュー、またはRollupは、データの新鮮さが高く、リフレッシュコストが低いです。しかし、v2.4以降でサポートされている非同期マテリアライズドビューと比較すると、同期マテリアライズドビューには多くの制限があります。クエリを加速または書き換えるために同期マテリアライズドビューを構築したい場合、集計演算子の選択肢が限られています。
以下の表は、StarRocksにおける非同期マテリアライズドビュー(ASYNC MV)と同期マテリアライズドビュー(SYNC MV)のサポートする機能の観点からの比較を示しています。
単一テーブル集計 | マルチテーブルジョイン | クエリの書き換え | リフレッシュ戦略 | ベーステーブル | |
---|---|---|---|---|---|
ASYNC MV | はい | はい | はい |
| 複数のテーブルから:
|
SYNC MV (Rollup) | 集計関数の選択肢が限られている | いいえ | はい | データロード中の同期リフレッシュ | Default Catalogの単一テーブル |
基本概念
-
ベーステーブル
ベーステーブルは、マテリアライズドビューの駆動テーブルです。
StarRocksの非同期マテリアライズドビューの場合、ベーステーブルはDefault CatalogのStarRocks内部テーブル、外部カタログのテーブル(v2.5からサポート)、または既存の非同期マテリアライズドビュー(v2.5からサポート)やビュー(v3.1からサポート)であることができます。StarRocksは、すべてのStarRocksテーブルタイプに対して非同期マテリアライズドビューの作成をサポートしています。
-
リフレッシュ
非同期マテリアライズドビューを作成すると、そのデータはその時点でのベーステーブルの状態を反映します。ベーステーブルのデータが変更された場合、マテリアライズドビューをリフレッシュして変更を同期させる必要があります。
現在、StarRocksは2つの一般的なリフレッシュ戦略をサポートしています。
- ASYNC: 非同期リフレッシュモード。ベーステーブルのデータが変更されたとき、または指定された間隔に基づいて定期的に、マテリアライズドビューを自動的にリフレッシュできます。
- MANUAL: 手動リフレッシュモード。マテリアライズドビューは自動的にリフレッシュされません。リフレッシュタスクはユーザーによって手動でトリガーされる必要があります。
-
クエリの書き換え
クエリの書き換えとは、マテリアライズドビューが構築されたベーステーブルに対してクエリを実行する際に、システムがマテリアライズドビューの事前計算された結果をクエリに再利用できるかどうかを自動的に判断することを意味します。再利用できる場合、システムは関連するマテリアライズドビューから直接データをロードし、時間とリソースを消費する計算やジョインを避けます。
v2.5以降、StarRocksはSPJGタイプの非同期マテリアライズドビューに基づく自動的で透明なクエリの書き換えをサポートしています。SPJGタイプのマテリアライズドビューは、プランにScan、Filter、Project、Aggregateタイプのオペレーターのみを含むマテリアライズドビューを指します。
注意
JDBCカタログまたはHudiカタログのベーステーブルに作成された非同期マテリアライズドビューは、クエリの書き換えをサポートしていません。
マテリアライズドビューを作成するタイミングを決定する
データウェアハウス環境で以下の要求がある場合、非同期マテリアライズドビューを作成できます。
-
繰り返しの集計関数を持つクエリの加速
データウェアハウスのほとんどのクエリが、集計関数を持つ同じサブクエリを含んでおり、これらのクエリが計算リソースの大部分を消費しているとします。このサブクエリに基づいて、非同期マテリアライズドビューを作成し、サブクエリのすべての結果を計算して保存できます。マテリアライズドビューが構築された後、StarRocksはサブクエリを含むすべてのクエリを書き換え、マテリアライズドビューに保存された中間結果をロードし、これらのクエリを加速します。
-
複数テーブルの定期的なジョイン
データウェアハウスで複数のテーブルを定期的にジョインして新しいワイドテーブルを作成する必要があるとします。これらのテーブルに対して非同期マテリアライズドビューを構築し、固定時間間隔でリフレッシュタスクをトリガーするASYNCリフレッシュ戦略を設定できます。マテリアライズドビューが構築された後、クエリ結果はマテリアライズドビューから直接返され、ジョイン操作による遅延が回避されます。
-
データウェアハウスのレイヤリング
データウェアハウスに大量の生データが含まれており、クエリが複雑なETL操作を必要とする場合、データウェアハウス内のデータを階層化するために複数の非同期マテリアライズドビューを構築し、クエリを一連の単純なサブクエリに分解できます。これにより、繰り返しの計算を大幅に削減し、さらに重要なことに、DBAが問題を簡単かつ効率的に特定するのに役立ちます。それに加えて、データウェアハウスのレイヤリングは、生データと統計データを分離し、機密性の高い生データのセキュリティを保護します。
-
データレイクでのクエリの加速
データレイクのクエリは、ネットワーク遅延やオブジェクトストレージのスループットのために遅くなることがあります。データレイクの上に非同期マテリアライズドビューを構築することで、クエリパフォーマンスを向上させることができます。さらに、StarRocksは既存のマテリアライズドビューを使用するようにクエリを書き換えることができ、クエリを手動で変更する手間を省くことができます。
非同期マテリアライズドビューの具体的な使用例については、以下のコンテンツを参照してください。
非同期マテリアライズドビューを作成する
StarRocksの非同期マテリアライズドビューは、以下のベーステーブルに基づいて作成できます。
- StarRocksの内部テーブル(すべてのStarRocksテーブルタイプがサポートされています)
- 外部カタログのテーブル
- 既存の非同期マテリアライズドビュー(v2.5以降)
- 既存のビュー(v3.1以降)
始める前に
以下の例では、Default Catalogの2つのベーステーブルを使用します。
- テーブル
goods
は、アイテムIDitem_id1
、アイテム名item_name
、アイテム価格price
を記録します。 - テーブル
order_list
は、注文IDorder_id
、クライアントIDclient_id
、アイテムIDitem_id2
、注文日order_date
を記録します。
カラム goods.item_id1
はカラム order_list.item_id2
と等価です。
以下のステートメントを実行してテーブルを作成し、データを挿入します。
CREATE TABLE goods(
item_id1 INT,
item_name STRING,
price FLOAT
) DISTRIBUTED BY HASH(item_id1);
INSERT INTO goods
VALUES
(1001,"apple",6.5),
(1002,"pear",8.0),
(1003,"potato",2.2);
CREATE TABLE order_list(
order_id INT,
client_id INT,
item_id2 INT,
order_date DATE
) DISTRIBUTED BY HASH(order_id);
INSERT INTO order_list
VALUES
(10001,101,1001,"2022-03-13"),
(10001,101,1002,"2022-03-13"),
(10002,103,1002,"2022-03-13"),
(10002,103,1003,"2022-03-14"),
(10003,102,1003,"2022-03-14"),
(10003,102,1001,"2022-03-14");
以下の例のシナリオでは、各注文の合計を頻繁に計算する必要があります。2つのベーステーブルを頻繁にジョインし、集計関数 sum()
を集中的に使用する必要があります。さらに、ビジネスシナリオでは、データのリフレッシュが1日間隔で必要です。
クエリステートメントは次のとおりです。
SELECT
order_id,
sum(goods.price) as total
FROM order_list INNER JOIN goods ON goods.item_id1 = order_list.item_id2
GROUP BY order_id;
マテリアライズドビューを作成する
特定のクエリステートメントに基づいてマテリアライズドビューを作成するには、CREATE MATERIALIZED VIEWを使用します。
テーブル goods
、order_list
、および上記のクエリステートメントに基づいて、以下の例では、各注文の合計を分析するためのマテリアライズドビュー order_mv
を作成します。マテリアライズドビューは1日間隔で自動的にリフレッシュされるように設定されています。
CREATE MATERIALIZED VIEW order_mv
DISTRIBUTED BY HASH(`order_id`)
REFRESH ASYNC START('2022-09-01 10:00:00') EVERY (interval 1 day)
AS SELECT
order_list.order_id,
sum(goods.price) as total
FROM order_list INNER JOIN goods ON goods.item_id1 = order_list.item_id2
GROUP BY order_id;
注意
- 非同期マテリアライズドビューを作成する際には、データ分散戦略またはマテリアライズドビューのリフレッシュ戦略、またはその両方を指定する必要があります。
- 非同期マテリアライズドビューには、ベーステーブルとは異なるパーティション化およびバケット化戦略を設定できますが、マテリアライズドビューを作成するために使用されるクエリステートメントには、マテリアライズドビューのパーティションキーとバケットキーを含める必要があります。
- 非同期マテリアライズドビューは、より長い期間の動的パーティション化戦略をサポートしています。たとえば、ベーステーブルが1日間隔でパーティション化されている場合、マテリアライズドビューを1か月間隔でパーティション化するように設定できます。
- v3.3.3以降、StarRocksはリストパーティション化戦略を使用した非同期マテリアライズドビューの作成をサポートしています。
- リストパーティション化または式に基づくパーティション化戦略で作成されたテーブルに基づいて、リストパーティション化されたマテリアライズドビューを作成できます。
- 現在、リストパーティション化戦略を使用してマテリアライズドビューを作成する際には、1つのパーティションキーのみを指定できます。ベーステーブルに複数のパーティションキーがある場合は、1つのパーティションキーを選択する必要があります。
- リストパーティション化戦略を使用したマテリアライズドビューのリフレッシュ動作とクエリの書き換えロジックは、レンジパーティション化戦略を使用したものと一致しています。
- マテリアライズドビューを作成するために使用されるクエリステートメントは、rand()、random()、uuid()、sleep()などのランダム関数をサポートしていません。
- 非同期マテリアライズドビューは、さまざまなデータタイプをサポートしています。詳細については、CREATE MATERIALIZED VIEW - サポートされるデータタイプを参照してください。
- デフォルトでは、CREATE MATERIALIZED VIEWステートメントを実行すると、すぐにリフレッシュタスクがトリガーされ、システムリソースの一定の割合を消費する可能性があります。リフレッシュタスクを遅らせたい場合は、CREATE MATERIALIZED VIEWステートメントにREFRESH DEFERREDパラメータを追加できます。
- マテリアライズドビューは、default_catalogにのみ作成できます。default_catalog.database.mvで作成するか、
set catalog <default_catalog>
ステートメントを使用してdefault_catalogに切り替えることができます。
-
非同期マテリアライズドビューのリフレッシュメカニズムについて
現在、StarRocksは2つのオンデマンドリフレッシュ戦略をサポートしています:MANUALリフレッシュとASYNCリフレッシュ。
StarRocks v2.5では、非同期マテリアライズドビューはリフレッシュのコストを制御し、成功率を高めるためのさまざまな非同期リフレッシュメカニズムをさらにサポートしています。
- MVに多くの大きなパーティションがある場合、各リフレッシュは大量のリソースを消費する可能性があります。v2.5では、StarRocksはリフレッシュタスクの分割をサポートしています。リフレッシュされる最大パーティション数を指定でき、StarRocksは指定された最大パーティション数以下のバッチサイズでバッチごとにリフレッシュを実行します。この機能により、大規模な非同期マテリアライズドビューが安定してリフレッシュされ、データモデリングの安定性と堅牢性が向上します。
- 非同期マテリアライズドビューのパーティションの有効期限(TTL)を指定して、マテリアライズドビューが占有するストレージサイズを削減できます。
- 最新のいくつかのパーティションのみをリフレッシュするためのリフレッシュ範囲を指定して、リフレッシュのオーバーヘッドを削減できます。
- データの変更が対応するマテリアライズドビューのリフレッシュを自動的にトリガーしないベーステーブルを指定できます。
- リフレッシュタスクにリソースグループを割り当てることができます。
詳細については、CREATE MATERIALIZED VIEW - パラメータのPROPERTIESセクションを参照してください。既存の非同期マテリアライズドビューのメカニズムを変更するには、ALTER MATERIALIZED VIEWを使用できます。
注意
フルリフレッシュ操作がシステムリソースを使い果たし、タスクの失敗を引き起こすのを防ぐために、パーティション化されたベーステーブルに基づいてパーティション化されたマテリアライズドビューを作成することをお勧めします。これにより、ベーステーブルのパーティション内でデータの更新が発生した場合、マテリアライズドビューの対応するパーティションのみがリフレッシュされ、マテリアライズドビュー全体をリフレッシュするのではなくなります。詳細については、Data Modeling with Materialized Views - Partitioned Modelingを参照してください。
-
ネストされたマテリアライズドビューについて
StarRocks v2.5は、ネストされた非同期マテリアライズドビューの作成をサポートしています。既存の非同期マテリアライズドビューに基づいて非同期マテリアライズドビューを構築できます。各マテリアライズドビューのリフレッシュ戦略は、上位または下位のマテリアライズドビューに影響を与えません。現在、StarRocksはネストのレベル数を制限していません。実稼働環境では、ネストのレイヤー数が3を超えないことをお勧めします。
-
外部カタログマテリアライズドビューについて
StarRocksは、Hive Catalog(v2.5以降)、Hudi Catalog(v2.5以降)、Iceberg Catalog(v2.5以降)、およびJDBC Catalog(v3.0以降)に基づいて非同期マテリアライズドビューを構築することをサポートしています。外部カタログにマテリアライズドビューを作成することは、Default Catalogに非同期マテリアライズドビューを作成することと似ていますが、いくつかの使用制限があります。詳細については、Data lake query acceleration with materialized viewsを参照してください。
非同期マテリアライズドビューを手動でリフレッシュする
非同期マテリアライズドビューは、そのリフレッシュ戦略に関係なく、REFRESH MATERIALIZED VIEWを使用してリフレッシュできます。StarRocks v2.5は、パーティション名を指定して非同期マテリアライズドビューの特定のパーティションをリフレッシュすることをサポートしています。StarRocks v3.1は、リフレッシュタスクの同期呼び出しをサポートしており、タスクが成功または失敗したときにのみSQLステートメントが返されます。
-- 非同期呼び出し(デフォルト)によるマテリアライズドビューのリフレッシュ。
REFRESH MATERIALIZED VIEW order_mv;
-- 同期呼び出しによるマテリアライズドビューのリフレッシュ。
REFRESH MATERIALIZED VIEW order_mv WITH SYNC MODE;
非同期呼び出しを介して送信されたリフレッシュタスクをキャンセルするには、CANCEL REFRESH MATERIALIZED VIEWを使用します。
非同期マテリアライズドビューを直接クエリする
作成した非同期マテリアライズドビューは、クエリステートメントに従って完全な事前計算結果を含む物理テーブルです。したがって、マテリアライズドビューが初めてリフレッシュされた後、マテリアライズドビューを直接クエリできます。
MySQL > SELECT * FROM order_mv;
+----------+--------------------+
| order_id | total |
+----------+--------------------+
| 10001 | 14.5 |
| 10002 | 10.200000047683716 |
| 10003 | 8.700000047683716 |
+----------+--------------------+
3 rows in set (0.01 sec)
注意
非同期マテリアライズドビューを直接クエリできますが、結果はベーステーブルに対するクエリから得られるものと一致しない場合があります。
非同期マテリアライズドビューでクエリをリライトして加速する
StarRocks v2.5は、SPJGタイプの非同期マテリアライズドビューに基づく自動的で透明なクエリの書き換えをサポートしています。SPJGタイプのマテリアライズドビューのクエリの書き換えには、単一テーブルクエリの書き換え、ジョインクエリの書き換え、集計クエリの書き換え、ユニオンクエリの書き換え、およびネストされたマテリアライズドビューに基づくクエリの書き換えが含まれます。v3.3.0以降、StarRocksはさらにテキストベースのマテリアライズドビューの書き換えをサポートしています。詳細については、Query Rewrite with Materialized Viewsを参照してください。
現在、StarRocksは、Default CatalogまたはHive Catalog、Hudi Catalog、Iceberg Catalogなどの外部カタログに作成された非同期マテリアライズドビューに対するクエリの書き換えをサポートしています。Default Catalogのデータをクエリする際、StarRocksは、データがベーステーブルと一致しないマテリアライズドビューを除外することで、書き換えられたクエリと元のクエリの結果の強い一貫性を保証します。マテリアライズドビューのデータが期限切れになると、マテリアライズドビューは候補として使用されません。外部カタログのデータをクエリする際、StarRocksは外部カタログのデータ変更を認識できないため、結果の強い一貫性を保証しません。外部カタログに基づいて作成された非同期マテリアライズドビューの詳細については、Data lake query acceleration with materialized viewsを参照してください。
注意
JDBCカタログのベーステーブルに作成された非同期マテリアライズドビューは、クエリの書き換えをサポートしていません。
非同期マテリアライズドビューを管理する
非同期マテリアライズドビューを変更する
ALTER MATERIALIZED VIEWを使用して、非同期マテリアライズドビューのプロパティを変更できます。
-
非アクティブなマテリアライズドビューを有効にする。
ALTER MATERIALIZED VIEW order_mv ACTIVE;
-
非同期マテリアライズドビューの名前を変更する。
ALTER MATERIALIZED VIEW order_mv RENAME order_total;
-
非同期マテリアライズドビューのリフレッシュ間隔を2日に変更する。
ALTER MATERIALIZED VIEW order_mv REFRESH ASYNC EVERY(INTERVAL 2 DAY);
非同期マテリアライズドビューを表示する
SHOW MATERIALIZED VIEWSを使用するか、Information Schemaのシステムメタデータビューをクエリすることで、データベース内の非同期マテリアライズドビューを表示できます。
-
データベース内のすべての非同期マテリアライズドビューを確認する。
SHOW MATERIALIZED VIEWS;
-
特定の非同期マテリアライズドビューを確認する。
SHOW MATERIALIZED VIEWS WHERE NAME = "order_mv";
-
名前に一致する特定の非同期マテリアライズドビューを確認する。
SHOW MATERIALIZED VIEWS WHERE NAME LIKE "order%";
-
Information Schemaのメタデータビュー
materialized_views
をクエリして、すべての非同期マテリアライズドビューを確認する。詳細については、information_schema.materialized_viewsを参照してください。SELECT * FROM information_schema.materialized_views;
非同期マテリアライズドビューの定義を確認する
SHOW CREATE MATERIALIZED VIEWを使用して、非同期マテリアライズドビューを作成するために使用されたクエリを確認できます。
SHOW CREATE MATERIALIZED VIEW order_mv;
非同期マテリアライズドビューの実行ステータスを確認する
tasks
およびtask_runs
をクエリすることで、非同期マテリアライズドビューの実行(構築またはリフレッシュ)ステータスを確認できます。
以下の例では、最も最近作成されたマテリアライズドビューの実行ステータスを確認します。
-
テーブル
tasks
で最も最近のタスクのTASK_NAME
を確認します。mysql> select * from information_schema.tasks order by CREATE_TIME desc limit 1\G;
*************************** 1. row ***************************
TASK_NAME: mv-59299
CREATE_TIME: 2022-12-12 17:33:51
SCHEDULE: MANUAL
DATABASE: ssb_1
DEFINITION: insert overwrite hive_mv_lineorder_flat_1 SELECT `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderkey`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_linenumber`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_custkey`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_partkey`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderpriority`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_ordtotalprice`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_revenue`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`p_mfgr`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`s_nation`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`c_city`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`c_nation`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderdate`
FROM `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`
WHERE `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderdate` = '1997-01-01'
EXPIRE_TIME: NULL
1 row in set (0.02 sec) -
見つけた
TASK_NAME
を使用して、テーブルtask_runs
で実行ステータスを確認します。mysql> select * from information_schema.task_runs where task_name='mv-59299' order by CREATE_TIME\G
*************************** 1. row ***************************
QUERY_ID: d9cef11f-7a00-11ed-bd90-00163e14767f
TASK_NAME: mv-59299
CREATE_TIME: 2022-12-12 17:39:19
FINISH_TIME: 2022-12-12 17:39:22
STATE: SUCCESS
DATABASE: ssb_1
DEFINITION: insert overwrite hive_mv_lineorder_flat_1 SELECT `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderkey`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_linenumber`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_custkey`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_partkey`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderpriority`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_ordtotalprice`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_revenue`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`p_mfgr`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`s_nation`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`c_city`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`c_nation`, `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderdate`
FROM `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`
WHERE `hive_ci`.`dla_scan`.`lineorder_flat_1000_1000_orc`.`lo_orderdate` = '1997-01-01'
EXPIRE_TIME: 2022-12-15 17:39:19
ERROR_CODE: 0
ERROR_MESSAGE: NULL
PROGRESS: 100%
2 rows in set (0.02 sec)
非同期マテリアライズドビューを削除する
非同期マテリアライズドビューは、DROP MATERIALIZED VIEWを使用して削除できます。
DROP MATERIALIZED VIEW order_mv;
関連するセッション変数
以下の変数は、非同期マテリアライズドビューの動作を制御します。
analyze_mv
: リフレッシュ後にマテリアライズドビューを分析するかどうか、およびその方法。 有効な値は、空の文字列(分析しない)、sample
(サンプル統計の収集)、およびfull
(完全統計の収集)です。デフォルトはsample
です。enable_materialized_view_rewrite
: マテリアライズドビューの自動書き換えを有効にするかどうか。有効な値はtrue
(v2.5以降のデフォルト)およびfalse
です。