* 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
4.3 KiB
Секция FROM
В секции FROM
указывается источник, из которого будут читаться данные:
- Таблица
- Подзапрос {## TODO: better link ##}
- Табличная функция
Секция JOIN и ARRAY JOIN могут быть использованы для расширения функциональных возможностей секции FROM
.
Подзапрос — дополнительный SELECT
запрос, который может быть указан в круглых скобках внутри секции FROM
.
Секция FROM
может содержать несколько источников данных, указанных через запятую, что эквивалентно выполнению CROSS JOIN на них.
Модификатор FINAL
Если в запросе используется модификатор FINAL
, то ClickHouse полностью мёржит данные перед выдачей результата, таким образом выполняя все преобразования данных, которые производятся движком таблиц при мёржах.
Он применим при выборе данных из таблиц, использующих MergeTree- семейство движков (кроме GraphiteMergeTree
). Также поддерживается для:
- Replicated варианты исполнения
MergeTree
движков. - View, Buffer, Distributed, и MaterializedView, которые работают поверх других движков, если они созданы для таблиц с движками семейства
MergeTree
.
Недостатки
Запросы, которые используют FINAL
выполняются не так быстро, как аналогичные запросы без него, потому что:
- Запрос выполняется в одном потоке, и данные мёржатся во время выполнения запроса.
- Запросы с модификатором
FINAL
читают столбцы первичного ключа в дополнение к столбцам, используемым в запросе.
В большинстве случаев избегайте использования FINAL
. Общий подход заключается в использовании агрегирующих запросов, которые предполагают, что фоновые процессы движков семейства MergeTree
ещё не случились (например, сами отбрасывают дубликаты). {## TODO: examples ##}
Детали реализации
Если секция FROM
опущена, данные будут считываться из таблицы system.one
.
Таблица system.one
содержит ровно одну строку.
Для выполнения запроса, из соответствующей таблицы, вынимаются все столбцы, перечисленные в запросе. Из подзапросов выкидываются столбцы, не нужные для внешнего запроса.
Если в запросе не перечислено ни одного столбца (например, SELECT count() FROM t)
, то из таблицы всё равно вынимается один какой-нибудь столбец (предпочитается самый маленький), для того, чтобы можно было посчитать количество строк.