2021-02-02 12:00:41 +00:00
|
|
|
---
|
2022-08-26 19:07:59 +00:00
|
|
|
slug: /zh/sql-reference/aggregate-functions/reference/grouparrayinsertat
|
2022-04-10 23:08:18 +00:00
|
|
|
sidebar_position: 112
|
2021-02-02 12:00:41 +00:00
|
|
|
---
|
|
|
|
|
|
|
|
# groupArrayInsertAt {#grouparrayinsertat}
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
在指定位置向数组中插入一个值。
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
**语法**
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` sql
|
|
|
|
groupArrayInsertAt(default_x, size)(x, pos);
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
如果在一个查询中将多个值插入到同一位置,则该函数的行为方式如下:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
- 如果在单个线程中执行查询,则使用第一个插入的值。
|
|
|
|
- 如果在多个线程中执行查询,则结果值是未确定的插入值之一。
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
**参数**
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2023-03-18 02:45:43 +00:00
|
|
|
- `x` — 要插入的值。生成所[支持的数据类型](../../../sql-reference/data-types/index.md)(数据)的[表达式](../../../sql-reference/syntax.md#syntax-expressions)。
|
2021-02-04 14:54:31 +00:00
|
|
|
- `pos` — 指定元素 `x` 将被插入的位置。 数组中的索引编号从零开始。 [UInt32](../../../sql-reference/data-types/int-uint.md#uint-ranges).
|
2021-03-22 15:56:44 +00:00
|
|
|
- `default_x` — 在空位置替换的默认值。可选参数。生成 `x` 数据类型 (数据) 的[表达式](../../../sql-reference/syntax.md#syntax-expressions)。 如果 `default_x` 未定义,则 [默认值](../../../sql-reference/statements/create.md#create-default-values) 被使用。
|
2021-02-04 14:54:31 +00:00
|
|
|
- `size`— 结果数组的长度。可选参数。如果使用该参数,必须指定默认值 `default_x` 。 [UInt32](../../../sql-reference/data-types/int-uint.md#uint-ranges)。
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
**返回值**
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
- 具有插入值的数组。
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
类型: [阵列](../../../sql-reference/data-types/array.md#data-type-array)。
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
**示例**
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
查询:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` sql
|
|
|
|
SELECT groupArrayInsertAt(toString(number), number * 2) FROM numbers(5);
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
结果:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` text
|
|
|
|
┌─groupArrayInsertAt(toString(number), multiply(number, 2))─┐
|
|
|
|
│ ['0','','1','','2','','3','','4'] │
|
|
|
|
└───────────────────────────────────────────────────────────┘
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
查询:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` sql
|
|
|
|
SELECT groupArrayInsertAt('-')(toString(number), number * 2) FROM numbers(5);
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
结果:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` text
|
|
|
|
┌─groupArrayInsertAt('-')(toString(number), multiply(number, 2))─┐
|
|
|
|
│ ['0','-','1','-','2','-','3','-','4'] │
|
|
|
|
└────────────────────────────────────────────────────────────────┘
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
查询:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` sql
|
|
|
|
SELECT groupArrayInsertAt('-', 5)(toString(number), number * 2) FROM numbers(5);
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
结果:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` text
|
|
|
|
┌─groupArrayInsertAt('-', 5)(toString(number), multiply(number, 2))─┐
|
|
|
|
│ ['0','-','1','-','2'] │
|
|
|
|
└───────────────────────────────────────────────────────────────────┘
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
在一个位置多线程插入数据。
|
2021-02-02 12:00:41 +00:00
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
查询:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` sql
|
|
|
|
SELECT groupArrayInsertAt(number, 0) FROM numbers_mt(10) SETTINGS max_block_size = 1;
|
|
|
|
```
|
|
|
|
|
2021-02-04 14:54:31 +00:00
|
|
|
作为这个查询的结果,你会得到 `[0,9]` 范围的随机整数。 例如:
|
2021-02-02 12:00:41 +00:00
|
|
|
|
|
|
|
``` text
|
|
|
|
┌─groupArrayInsertAt(number, 0)─┐
|
|
|
|
│ [7] │
|
|
|
|
└───────────────────────────────┘
|
|
|
|
```
|