* split up select.md * array-join.md basic refactoring * distinct.md basic refactoring * format.md basic refactoring * from.md basic refactoring * group-by.md basic refactoring * having.md basic refactoring * additional index.md refactoring * into-outfile.md basic refactoring * join.md basic refactoring * limit.md basic refactoring * limit-by.md basic refactoring * order-by.md basic refactoring * prewhere.md basic refactoring * adjust operators/index.md links * adjust sample.md links * adjust more links * adjust operatots links * fix some links * adjust aggregate function article titles * basic refactor of remaining select clauses * absolute paths in make_links.sh * run make_links.sh * remove old select.md locations * translate docs/es * translate docs/fr * translate docs/fa * remove old operators.md location * change operators.md links * adjust links in docs/es * adjust links in docs/es * minor texts adjustments * wip * update machine translations to use new links * fix changelog * es build fixes * get rid of some select.md links * temporary adjust ru links * temporary adjust more ru links * improve curly brace handling * adjust ru as well * fa build fix * ru link fixes * zh link fixes * temporary disable part of anchor checks
3.4 KiB
machine_translated | machine_translated_rev | toc_priority | toc_title |
---|---|---|---|
true | 72537a2d52 |
33 | جایگزینی |
جایگزینی
موتور متفاوت از ادغام در که حذف نوشته های تکراری با همان مقدار اصلی کلید (یا دقیق تر, با همان کلید مرتب سازی ارزش).
تقسیم داده ها تنها در یک ادغام رخ می دهد. ادغام در پس زمینه در زمان ناشناخته رخ می دهد بنابراین شما نمی توانید برنامه ریزی کنید. برخی از داده ها ممکن است بدون پردازش باقی می ماند. اگر چه شما می توانید ادغام برنامه ریزی با استفاده از اجرا OPTIMIZE
پرس و جو, در استفاده از این حساب نمی, به این دلیل که OPTIMIZE
پرس و جو خواندن و نوشتن مقدار زیادی از داده ها.
بدین ترتیب, ReplacingMergeTree
مناسب برای پاک کردن داده های تکراری در پس زمینه برای صرفه جویی در فضا است اما عدم وجود تکراری را تضمین نمی کند.
ایجاد یک جدول
CREATE TABLE [IF NOT EXISTS] [db.]table_name [ON CLUSTER cluster]
(
name1 [type1] [DEFAULT|MATERIALIZED|ALIAS expr1],
name2 [type2] [DEFAULT|MATERIALIZED|ALIAS expr2],
...
) ENGINE = ReplacingMergeTree([ver])
[PARTITION BY expr]
[ORDER BY expr]
[PRIMARY KEY expr]
[SAMPLE BY expr]
[SETTINGS name=value, ...]
برای شرح پارامترهای درخواست را ببینید درخواست توضیحات.
پارامترهای جایگزین
-
ver
— column with version. TypeUInt*
,Date
یاDateTime
. پارامتر اختیاری.هنگام ادغام,
ReplacingMergeTree
از تمام ردیف ها با همان کلید اصلی تنها یک برگ دارد:- گذشته در انتخاب, اگر
ver
تنظیم نشده است. - با حداکثر نسخه, اگر
ver
مشخص.
- گذشته در انتخاب, اگر
بندهای پرسوجو
هنگام ایجاد یک ReplacingMergeTree
جدول همان بند در هنگام ایجاد یک مورد نیاز است MergeTree
جدول
روش منسوخ برای ایجاد یک جدول
!!! attention "توجه" هنوز این روش در پروژه های جدید استفاده کنید و, در صورت امکان, تغییر پروژه های قدیمی به روش بالا توضیح.
CREATE TABLE [IF NOT EXISTS] [db.]table_name [ON CLUSTER cluster]
(
name1 [type1] [DEFAULT|MATERIALIZED|ALIAS expr1],
name2 [type2] [DEFAULT|MATERIALIZED|ALIAS expr2],
...
) ENGINE [=] ReplacingMergeTree(date-column [, sampling_expression], (primary, key), index_granularity, [ver])
همه پارامترها به استثنای ver
همان معنی را در MergeTree
.
ver
- ستون با نسخه . پارامتر اختیاری. برای شرح, متن بالا را ببینید.