ClickHouse/docs/tr/engines/table-engines/special/merge.md
Ivan Blinkov cd14f9ebcb
SQL reference refactoring (#10857)
* 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
2020-05-15 07:34:54 +03:00

3.3 KiB
Raw Blame History

machine_translated machine_translated_rev toc_priority toc_title
true 72537a2d52 36 Birleştirmek

Birleştirmek

Bu Merge motor (ile karıştırılmamalıdır MergeTree) verileri kendisi saklamaz, ancak aynı anda herhangi bir sayıda başka tablodan okumaya izin verir. Okuma otomatik olarak paralelleştirilir. Bir tabloya yazma desteklenmiyor. Okurken, gerçekten okunmakta olan tabloların dizinleri varsa kullanılır. Bu Merge motor parametreleri kabul eder: veritabanı adı ve tablolar için düzenli ifade.

Örnek:

Merge(hits, '^WatchLog')

Veri tablolardan okunacak hits düzenli ifadeyle eşleşen adlara sahip veritabanı ^WatchLog.

Veritabanı adı yerine, bir dize döndüren sabit bir ifade kullanabilirsiniz. Mesela, currentDatabase().

Regular expressions — re2 (pcre bir alt kümesini destekler), büyük / küçük harf duyarlı. Düzenli ifadelerde kaçan sembollerle ilgili notlara bakın “match” bölme.

Okumak için tabloları seçerken, Merge regex ile eşleşse bile tablonun kendisi seçilmeyecektir. Bu döngülerden kaçınmaktır. İki tane oluşturmak mümkündür Merge sonsuza kadar birbirlerinin verilerini okumaya çalışacak tablolar, ancak bu iyi bir fikir değil.

Kullanmak için tipik bir yol Merge motor çok sayıda çalışma içindir TinyLog tablolar tek bir tablo ile sanki.

Örnek 2:

Diyelim ki eski bir tablonuz (WatchLog_old) var ve verileri yeni bir tabloya (WatchLog_new) taşımadan bölümlemeyi değiştirmeye karar verdiniz ve her iki tablodaki verileri görmeniz gerekiyor.

CREATE TABLE WatchLog_old(date Date, UserId Int64, EventType String, Cnt UInt64)
ENGINE=MergeTree(date, (UserId, EventType), 8192);
INSERT INTO WatchLog_old VALUES ('2018-01-01', 1, 'hit', 3);

CREATE TABLE WatchLog_new(date Date, UserId Int64, EventType String, Cnt UInt64)
ENGINE=MergeTree PARTITION BY date ORDER BY (UserId, EventType) SETTINGS index_granularity=8192;
INSERT INTO WatchLog_new VALUES ('2018-01-02', 2, 'hit', 3);

CREATE TABLE WatchLog as WatchLog_old ENGINE=Merge(currentDatabase(), '^WatchLog');

SELECT *
FROM WatchLog
┌───────date─┬─UserId─┬─EventType─┬─Cnt─┐
│ 2018-01-01 │      1 │ hit       │   3 │
└────────────┴────────┴───────────┴─────┘
┌───────date─┬─UserId─┬─EventType─┬─Cnt─┐
│ 2018-01-02 │      2 │ hit       │   3 │
└────────────┴────────┴───────────┴─────┘

Sanal Sütunlar

  • _table — Contains the name of the table from which data was read. Type: Dize.

    Sabit koşulları ayarlayabilirsiniz _table in the WHERE/PREWHERE fıkra (sı (örneğin, WHERE _table='xyz'). Bu durumda, okuma işlemi yalnızca koşulun açık olduğu tablolar için gerçekleştirilir _table memnun olduğunu, bu yüzden _table sütun bir dizin görevi görür.

Ayrıca Bakınız

Orijinal makale