ClickHouse/docs/ru/engines/table-engines/integrations/mongodb.md

71 lines
1.8 KiB
Markdown
Raw Normal View History

2021-02-07 14:29:54 +00:00
---
2022-08-26 17:37:11 +00:00
slug: /ru/engines/table-engines/integrations/mongodb
sidebar_position: 5
sidebar_label: MongoDB
2021-02-07 14:29:54 +00:00
---
# MongoDB {#mongodb}
2021-02-08 14:30:59 +00:00
Движок таблиц MongoDB позволяет читать данные из коллекций СУБД MongoDB. В таблицах допустимы только плоские (не вложенные) типы данных. Запись (`INSERT`-запросы) не поддерживается.
2021-02-07 14:29:54 +00:00
## Создание таблицы {#creating-a-table}
``` sql
CREATE TABLE [IF NOT EXISTS] [db.]table_name
(
name1 [type1],
name2 [type2],
...
2021-09-07 17:07:27 +00:00
) ENGINE = MongoDB(host:port, database, collection, user, password [, options]);
2021-02-07 14:29:54 +00:00
```
**Параметры движка**
- `host:port` — адрес сервера MongoDB.
- `database` — имя базы данных на удалённом сервере.
2021-02-08 14:27:59 +00:00
- `collection` — имя коллекции на удалённом сервере.
2021-02-07 14:29:54 +00:00
- `user` — пользователь MongoDB.
- `password` — пароль пользователя.
2021-09-07 17:07:27 +00:00
- `options` — MongoDB connection string options (optional parameter).
2021-02-07 14:29:54 +00:00
## Примеры использования {#usage-example}
Создание таблицы в ClickHouse для чтения данных из коллекции MongoDB:
2021-02-07 14:29:54 +00:00
2021-09-07 17:07:27 +00:00
``` sql
2021-02-07 14:29:54 +00:00
CREATE TABLE mongo_table
(
2021-07-29 15:20:55 +00:00
key UInt64,
2021-02-07 14:29:54 +00:00
data String
2021-02-08 14:27:59 +00:00
) ENGINE = MongoDB('mongo1:27017', 'test', 'simple_table', 'testuser', 'clickhouse');
2021-02-07 14:29:54 +00:00
```
Чтение с сервера MongoDB, защищенного SSL:
2021-09-07 17:07:27 +00:00
``` sql
CREATE TABLE mongo_table_ssl
(
key UInt64,
data String
) ENGINE = MongoDB('mongo2:27017', 'test', 'simple_table', 'testuser', 'clickhouse', 'ssl=true');
```
2021-02-07 14:29:54 +00:00
Запрос к таблице:
``` sql
SELECT COUNT() FROM mongo_table;
```
``` text
┌─count()─┐
│ 4 │
└─────────┘
```