الانتقال إلى المحتوى الرئيسي
يمكنك تعديل استعلام SELECT الذي جرى تحديده عند إنشاء عرض مادي باستخدام التعليمة ALTER TABLE ... MODIFY QUERY من دون مقاطعة عملية الإدخال. صُمم هذا الأمر لتعديل عرض مادي أُنشئ باستخدام العبارة TO [db.]name. وهو لا يغيّر بنية جدول التخزين الأساسي، كما لا يغيّر تعريف أعمدة العرض المادي، لذلك يكون استخدام هذا الأمر محدودًا جدًا مع العروض المادية التي أُنشئت من دون العبارة TO [db.]name. مثال مع جدول TO
CREATE TABLE events (ts DateTime, event_type String)
ENGINE = MergeTree ORDER BY (event_type, ts);

CREATE TABLE events_by_day (ts DateTime, event_type String, events_cnt UInt64)
ENGINE = SummingMergeTree ORDER BY (event_type, ts);

CREATE MATERIALIZED VIEW mv TO events_by_day AS
SELECT toStartOfDay(ts) ts, event_type, count() events_cnt
FROM events
GROUP BY ts, event_type;

INSERT INTO events
SELECT DATE '2020-01-01' + interval number * 900 second,
       ['imp', 'click'][number%2+1]
FROM numbers(100);

SELECT ts, event_type, sum(events_cnt)
FROM events_by_day
GROUP BY ts, event_type
ORDER BY ts, event_type;

┌──────────────────ts─┬─event_type─┬─sum(events_cnt)─┐
2020-01-01 00:00:00 │ click      │              48
2020-01-01 00:00:00 │ imp        │              48
2020-01-02 00:00:00 │ click      │               2
2020-01-02 00:00:00 │ imp        │               2
└─────────────────────┴────────────┴─────────────────┘

-- Let's add the new measurement `cost`
-- and the new dimension `browser`.

ALTER TABLE events
  ADD COLUMN browser String,
  ADD COLUMN cost Float64;

-- Column do not have to match in a materialized view and TO
-- (destination table), so the next alter does not break insertion.

ALTER TABLE events_by_day
    ADD COLUMN cost Float64,
    ADD COLUMN browser String after event_type,
    MODIFY ORDER BY (event_type, ts, browser);

INSERT INTO events
SELECT Date '2020-01-02' + interval number * 900 second,
       ['imp', 'click'][number%2+1],
       ['firefox', 'safary', 'chrome'][number%3+1],
       10/(number+1)%33
FROM numbers(100);

-- New columns `browser` and `cost` are empty because we did not change Materialized View yet.

SELECT ts, event_type, browser, sum(events_cnt) events_cnt, round(sum(cost),2) cost
FROM events_by_day
GROUP BY ts, event_type, browser
ORDER BY ts, event_type;

┌──────────────────ts─┬─event_type─┬─browser─┬─events_cnt─┬─cost─┐
2020-01-01 00:00:00 │ click      │         │         480
2020-01-01 00:00:00 │ imp        │         │         480
2020-01-02 00:00:00 │ click      │         │         500
2020-01-02 00:00:00 │ imp        │         │         500
2020-01-03 00:00:00 │ click      │         │          20
2020-01-03 00:00:00 │ imp        │         │          20
└─────────────────────┴────────────┴─────────┴────────────┴──────┘

ALTER TABLE mv MODIFY QUERY
  SELECT toStartOfDay(ts) ts, event_type, browser,
  count() events_cnt,
  sum(cost) cost
  FROM events
  GROUP BY ts, event_type, browser;

INSERT INTO events
SELECT Date '2020-01-03' + interval number * 900 second,
       ['imp', 'click'][number%2+1],
       ['firefox', 'safary', 'chrome'][number%3+1],
       10/(number+1)%33
FROM numbers(100);

SELECT ts, event_type, browser, sum(events_cnt) events_cnt, round(sum(cost),2) cost
FROM events_by_day
GROUP BY ts, event_type, browser
ORDER BY ts, event_type;

┌──────────────────ts─┬─event_type─┬─browser─┬─events_cnt─┬──cost─┐
2020-01-01 00:00:00 │ click      │         │         480
2020-01-01 00:00:00 │ imp        │         │         480
2020-01-02 00:00:00 │ click      │         │         500
2020-01-02 00:00:00 │ imp        │         │         500
2020-01-03 00:00:00 │ click      │ firefox │         166.84
2020-01-03 00:00:00 │ click      │         │          20
2020-01-03 00:00:00 │ click      │ safary  │         169.82
2020-01-03 00:00:00 │ click      │ chrome  │         165.63
2020-01-03 00:00:00 │ imp        │         │          20
2020-01-03 00:00:00 │ imp        │ firefox │         1615.14
2020-01-03 00:00:00 │ imp        │ safary  │         166.14
2020-01-03 00:00:00 │ imp        │ chrome  │         167.89
2020-01-04 00:00:00 │ click      │ safary  │          10.1
2020-01-04 00:00:00 │ click      │ firefox │          10.1
2020-01-04 00:00:00 │ imp        │ firefox │          10.1
2020-01-04 00:00:00 │ imp        │ chrome  │          10.1
└─────────────────────┴────────────┴─────────┴────────────┴───────┘

-- !!! During `MODIFY ORDER BY` PRIMARY KEY was implicitly introduced.

SHOW CREATE TABLE events_by_day FORMAT TSVRaw

CREATE TABLE test.events_by_day
(
    `ts` DateTime,
    `event_type` String,
    `browser` String,
    `events_cnt` UInt64,
    `cost` Float64
)
ENGINE = SummingMergeTree
PRIMARY KEY (event_type, ts)
ORDER BY (event_type, ts, browser)

-- !!! The columns' definition is unchanged but it does not matter, we are not querying
-- MATERIALIZED VIEW, we are querying TO (storage) table.
-- SELECT section is updated.

SHOW CREATE TABLE mv FORMAT TSVRaw;

CREATE MATERIALIZED VIEW test.mv TO test.events_by_day
(
    `ts` DateTime,
    `event_type` String,
    `events_cnt` UInt64
) AS
SELECT
    toStartOfDay(ts) AS ts,
    event_type,
    browser,
    count() AS events_cnt,
    sum(cost) AS cost
FROM test.events
GROUP BY
    ts,
    event_type,
    browser
مثال من دون جدول TO التطبيق محدود جدًا، إذ لا يمكنك سوى تغيير قسم SELECT من دون إضافة أعمدة جديدة.
CREATE TABLE src_table (`a` UInt32) ENGINE = MergeTree ORDER BY a;
CREATE MATERIALIZED VIEW mv (`a` UInt32) ENGINE = MergeTree ORDER BY a AS SELECT a FROM src_table;
INSERT INTO src_table (a) VALUES (1), (2);
SELECT * FROM mv;
┌─a─┐
│ 1 │
│ 2 │
└───┘
ALTER TABLE mv MODIFY QUERY SELECT a * 2 as a FROM src_table;
INSERT INTO src_table (a) VALUES (3), (4);
SELECT * FROM mv;
┌─a─┐
│ 6 │
│ 8 │
└───┘
┌─a─┐
│ 1 │
│ 2 │
└───┘

تعليمة ALTER TABLE … MODIFY REFRESH

تُغيّر ALTER TABLE ... MODIFY REFRESH مَعلمات التحديث الخاصة بـ العرض المادي القابل للتحديث، بما في ذلك الجدول الزمني، والتبعيات، والعشوائية، وإعدادات التحديث.
ALTER TABLE [db.]name MODIFY REFRESH EVERY|AFTER ... [RANDOMIZE FOR ...] [DEPENDS ON ...] [SETTINGS ...]
الجدولة (EVERY أو AFTER) إلزامية: إذ تستبدل التعليمة جميع معلمات التحديث دفعةً واحدة. وأي عبارة لا تُحدَّد — RANDOMIZE FOR أو DEPENDS ON أو SETTINGS — تُزال أو تُعاد إلى قيمها الافتراضية. ولتغيير إعدادات التحديث فقط، أعِد استخدام الجدولة الحالية.
-- Change the schedule.
ALTER TABLE rmv MODIFY REFRESH EVERY 30 MINUTE;

-- Change retry settings (schedule must be repeated).
ALTER TABLE rmv MODIFY REFRESH EVERY 1 HOUR
SETTINGS refresh_retries = 5,
         refresh_retry_initial_backoff_ms = 500,
         refresh_retry_max_backoff_ms = 60000;

-- Add or keep a dependency.
ALTER TABLE rmv MODIFY REFRESH EVERY 6 HOUR DEPENDS ON other_rmv;

-- Drop the dependency by omitting `DEPENDS ON`.
ALTER TABLE rmv MODIFY REFRESH EVERY 6 HOUR;
القيود:
  • ALTER TABLE ... MODIFY SETTING غير مدعوم في العروض المادية؛ ولا يمكن تغيير إعدادات التحديث إلا عبر MODIFY REFRESH.
  • لا يدعم إضافة APPEND أو إزالته.
  • لا يمكن تغيير إعداد التحديث all_replicas بعد إنشاء العرض.
القائمة الكاملة لإعدادات التحديث موثقة في إعدادات التحديث. كما تظهر حالة التحديث، بما في ذلك الإعدادات المطبقة حاليًا، في system.view_refreshes.
آخر تعديل في ٢٥ يونيو ٢٠٢٦