2018-11-30 19:26:35 +00:00
|
|
|
|
# Join
|
|
|
|
|
|
2019-04-08 16:07:11 +00:00
|
|
|
|
加载好的 JOIN 表数据会常驻内存中。
|
2018-11-30 19:26:35 +00:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
Join(ANY|ALL, LEFT|INNER, k1[, k2, ...])
|
|
|
|
|
```
|
|
|
|
|
|
2019-04-08 16:07:11 +00:00
|
|
|
|
引擎参数:`ANY|ALL` – 连接修饰;`LEFT|INNER` – 连接类型。更多信息可参考 [JOIN子句](../../query_language/select.md#select-join)。
|
|
|
|
|
这些参数设置不用带引号,但必须与要 JOIN 表匹配。 k1,k2,……是 USING 子句中要用于连接的关键列。
|
2018-11-30 19:26:35 +00:00
|
|
|
|
|
2019-04-08 16:07:11 +00:00
|
|
|
|
此引擎表不能用于 GLOBAL JOIN 。
|
2018-11-30 19:26:35 +00:00
|
|
|
|
|
2019-04-08 16:07:11 +00:00
|
|
|
|
类似于 Set 引擎,可以使用 INSERT 向表中添加数据。设置为 ANY 时,重复键的数据会被忽略(仅一条用于连接)。设置为 ALL 时,重复键的数据都会用于连接。不能直接对 JOIN 表进行 SELECT。检索其数据的唯一方法是将其作为 JOIN 语句右边的表。
|
2018-11-30 19:26:35 +00:00
|
|
|
|
|
2019-04-08 16:07:11 +00:00
|
|
|
|
跟 Set 引擎类似,Join 引擎把数据存储在磁盘中。
|
2018-11-30 19:26:35 +00:00
|
|
|
|
|
2020-01-28 15:27:44 +00:00
|
|
|
|
### Limitations and Settings {#join-limitations-and-settings}
|
|
|
|
|
|
|
|
|
|
When creating a table, the following settings are applied:
|
|
|
|
|
|
|
|
|
|
- join_use_nulls
|
|
|
|
|
- max_rows_in_join
|
|
|
|
|
- max_bytes_in_join
|
|
|
|
|
- join_overflow_mode
|
|
|
|
|
- join_any_take_last_row
|
|
|
|
|
|
|
|
|
|
The `Join`-engine tables can't be used in `GLOBAL JOIN` operations.
|
2018-11-30 19:26:35 +00:00
|
|
|
|
|
2019-04-08 16:07:11 +00:00
|
|
|
|
[来源文章](https://clickhouse.yandex/docs/en/operations/table_engines/join/) <!--hide-->
|