mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-08 08:35:20 +00:00
831135432f
Signed-off-by: Slach <bloodjazman@gmail.com>
103 lines
4.5 KiB
Markdown
103 lines
4.5 KiB
Markdown
---
|
||
toc_priority: 8
|
||
toc_title: PostgreSQL
|
||
---
|
||
|
||
# PosgtreSQL {#postgresql}
|
||
|
||
Движок PostgreSQL позволяет выполнять запросы `SELECT` над данными, хранящимися на удалённом PostgreSQL сервере.
|
||
|
||
## Создание таблицы {#creating-a-table}
|
||
|
||
``` sql
|
||
CREATE TABLE [IF NOT EXISTS] [db.]table_name [ON CLUSTER cluster]
|
||
(
|
||
name1 [type1] [DEFAULT|MATERIALIZED|ALIAS expr1] [TTL expr1],
|
||
name2 [type2] [DEFAULT|MATERIALIZED|ALIAS expr2] [TTL expr2],
|
||
...
|
||
) ENGINE = PostgreSQL('host:port', 'database', 'table', 'user', 'password');
|
||
```
|
||
|
||
Смотрите подробное описание запроса [CREATE TABLE](../../../sql-reference/statements/create/table.md#create-table-query).
|
||
|
||
Структура таблицы может отличаться от исходной структуры таблицы PostgreSQL:
|
||
|
||
- Имена столбцов должны быть такими же, как в исходной таблице MySQL, но вы можете использовать только некоторые из этих столбцов и в любом порядке.
|
||
- Типы столбцов могут отличаться от типов в исходной таблице PostgreSQL. ClickHouse пытается [приводить](../../../sql-reference/functions/type-conversion-functions.md#type_conversion_function-cast) values to the ClickHouse data types.
|
||
|
||
**Параметры движка**
|
||
|
||
- `host:port` — адрес сервера PostgreSQL.
|
||
|
||
- `database` — Имя базы данных на сервере PostgreSQL.
|
||
|
||
- `table` — Имя таблицы.
|
||
|
||
- `user` — Имя пользователя PostgreSQL.
|
||
|
||
- `password` — Пароль пользователя PostgreSQL.
|
||
|
||
SELECT запросы на стороне PostgreSQL выполняются как `COPY (SELECT ...) TO STDOUT` внутри транзакции PostgreSQL только на чтение с коммитом после каждого `SELECT` запроса.
|
||
|
||
Простые условия для `WHERE` такие как `=, !=, >, >=, <, <=, IN` исполняются на стороне PostgreSQL сервера.
|
||
|
||
Все операции объединения, аггрегации, сортировки, условия `IN [ array ]` и ограничения `LIMIT` выполняются на стороне ClickHouse только после того как запрос к PostgreSQL закончился.
|
||
|
||
INSERT запросы на стороне PostgreSQL выполняются как `COPY "table_name" (field1, field2, ... fieldN) FROM STDIN` внутри PostgreSQL транзакции с автоматическим коммитом после каждого `INSERT` запроса.
|
||
|
||
PostgreSQL массивы конвертируются в массивы ClickHouse.
|
||
|
||
## Пример использования {#usage-example}
|
||
|
||
Таблица в PostgreSQL:
|
||
|
||
``` text
|
||
postgres=# CREATE TABLE "public"."test" (
|
||
"int_id" SERIAL,
|
||
"int_nullable" INT NULL DEFAULT NULL,
|
||
"float" FLOAT NOT NULL,
|
||
"str" VARCHAR(100) NOT NULL DEFAULT '',
|
||
"float_nullable" FLOAT NULL DEFAULT NULL,
|
||
PRIMARY KEY (int_id));
|
||
|
||
CREATE TABLE
|
||
|
||
postgres=# insert into test (int_id, str, "float") VALUES (1,'test',2);
|
||
INSERT 0 1
|
||
|
||
postgresql> select * from test;
|
||
int_id | int_nullable | float | str | float_nullable
|
||
--------+--------------+-------+------+----------------
|
||
1 | | 2 | test |
|
||
(1 row)
|
||
```
|
||
|
||
Таблица в ClickHouse, получение данных из PostgreSQL таблицы созданной выше:
|
||
|
||
``` sql
|
||
CREATE TABLE default.postgresql_table
|
||
(
|
||
`float_nullable` Nullable(Float32),
|
||
`str` String,
|
||
`int_id` Int32
|
||
)
|
||
ENGINE = PostgreSQL('localhost:5432', 'public', 'test', 'postges_user', 'postgres_password');
|
||
```
|
||
|
||
``` sql
|
||
SELECT * FROM postgresql_table WHERE str IN ('test')
|
||
```
|
||
|
||
``` text
|
||
┌─float_nullable─┬─str──┬─int_id─┐
|
||
│ ᴺᵁᴸᴸ │ test │ 1 │
|
||
└────────────────┴──────┴────────┘
|
||
1 rows in set. Elapsed: 0.019 sec.
|
||
```
|
||
|
||
|
||
## Смотри также {#see-also}
|
||
|
||
- [Табличная функция ‘postgresql’](../../../sql-reference/table-functions/postgresql.md)
|
||
- [Использование PostgreSQL в качестве истояника для внешнего словаря](../../../sql-reference/dictionaries/external-dictionaries/external-dicts-dict-sources.md#dicts-external_dicts_dict_sources-postgresql)
|