ClickHouse/docs/ru/sql-reference/statements/detach.md

70 lines
3.3 KiB
Markdown
Raw Normal View History

---
toc_priority: 43
toc_title: DETACH
---
# DETACH {#detach-statement}
2021-03-17 00:09:42 +00:00
Заставляет сервер "забыть" о существовании таблицы или материализованного представления.
2021-03-15 18:36:42 +00:00
Синтаксис:
``` sql
DETACH TABLE|VIEW [IF EXISTS] [db.]name [ON CLUSTER cluster] [PERMANENTLY]
```
2021-03-17 00:09:42 +00:00
Но ни данные, ни метаданные таблицы или материализованного представления не удаляются. При следующем запуске сервера, если не было использовано `PERMANENTLY`, сервер прочитает метаданные и снова узнает о таблице/представлении. Если таблица или представление были отключены перманентно, сервер не подключит их обратно автоматически.
2021-03-15 18:36:42 +00:00
2021-03-17 00:09:42 +00:00
Независимо от того, каким способом таблица была отключена, ее можно подключить обратно с помощью запроса [ATTACH](../../sql-reference/statements/attach.md). Системные log таблицы также могут быть подключены обратно (к примеру `query_log`, `text_log` и др.) Другие системные таблицы не могут быть подключены обратно, но на следующем запуске сервер снова "вспомнит" об этих таблицах.
2021-03-15 18:36:42 +00:00
2021-03-17 00:09:42 +00:00
`ATTACH MATERIALIZED VIEW` не может быть использован с кратким синтаксисом (без `SELECT`), но можно подключить представление с помощью запроса `ATTACH TABLE`.
2021-03-15 18:36:42 +00:00
2021-03-17 00:09:42 +00:00
Обратите внимание, что нельзя перманентно отключить таблицу, которая уже временно отключена. Для этого ее сначала надо подключить обратно, а затем снова отключить перманентно.
2021-03-15 18:36:42 +00:00
2021-03-17 00:09:42 +00:00
Также нельзя использовать [DROP](../../sql-reference/statements/drop.md#drop-table) с отключенной таблицей или создавать таблицу с помощью [CREATE TABLE](../../sql-reference/statements/create/table.md) с таким же именем, как у отключенной таблицы. Еще нельзя заменить отключенную таблицу другой с помощью запроса [RENAME TABLE](../../sql-reference/statements/rename.md).
2021-03-15 18:36:42 +00:00
**Пример**
Создание таблицы:
Запрос:
``` sql
CREATE TABLE test ENGINE = Log AS SELECT * FROM numbers(10);
SELECT * FROM test;
```
2021-03-15 18:36:42 +00:00
Результат:
``` text
┌─number─┐
│ 0 │
│ 1 │
│ 2 │
│ 3 │
│ 4 │
│ 5 │
│ 6 │
│ 7 │
│ 8 │
│ 9 │
└────────┘
```
2021-03-17 00:09:42 +00:00
Отключение таблицы:
2021-03-15 18:36:42 +00:00
Запрос:
``` sql
DETACH TABLE test;
SELECT * FROM test;
```
Результат:
``` text
Received exception from server (version 21.4.1):
Code: 60. DB::Exception: Received from localhost:9000. DB::Exception: Table default.test doesn't exist.
```