ARRAY_PUSHFRONT
array_pushfront
描述
在数组开头添加一个元素。函数会返回一个新数组,包含新添加的元素以及原数组的所有元素。
语法
array_pushfront(ARRAY<T> arr, T element)
参数
arr
:ARRAY类型,要添加元素的数组 element
:T 类型,要添加到数组开头的元素
T 支持的类型:
- 数值类型:TINYINT、SMALLINT、INT、BIGINT、LARGEINT、FLOAT、DOUBLE、DECIMAL
- 字符串类型:CHAR、VARCHAR、STRING
- 日期时间类型:DATE、DATETIME、DATEV2、DATETIMEV2
- 布尔类型:BOOLEAN
- IP 类型:IPV4、IPV6
- 复杂类型:ARRAY、MAP、STRUCT
返回值
返回类型:ARRAY
返回值含义:
- 返回一个新数组,包含新添加的元素以及原数组的所有元素
- NULL:如果输入数组为 NULL
使用说明:
- 函数会在数组开头添加指定的元素
- 空数组可以正常添加元素,新元素的类型需要与数组元素类型兼容
- 对数组元素中的 null 值:null 元素会被正常处理
查询示例:
在字符串数组开头添加元素:
SELECT array_pushfront(['banana', 'cherry', 'date'], 'apple');
+--------------------------------------------------------+
| array_pushfront(['banana', 'cherry', 'date'], 'apple') |
+--------------------------------------------------------+
| ["apple", "banana", "cherry", "date"] |
+--------------------------------------------------------+
在包含 null 的数组开头添加null元素:
SELECT array_pushfront([1, null, 3], null);
+-------------------------------------+
| array_pushfront([1, null, 3], null) |
+-------------------------------------+
| [null, 1, null, 3] |
+-------------------------------------+
在空数组开头添加元素:
SELECT array_pushfront([], 42);
+--------------------------+
| array_pushfront([], 42) |
+--------------------------+
| [42] |
+--------------------------+
NULL 数组返回 NULL:
SELECT array_pushfront(NULL, 1);
+---------------------------+
| array_pushfront(NULL, 1) |
+---------------------------+
| NULL |
+---------------------------+
在浮点数数组开头添加元素:
SELECT array_pushfront([2.2, 3.3, 4.4], 1.1);
+------------------------------------------+
| array_pushfront([2.2, 3.3, 4.4], 1.1) |
+------------------------------------------+
| [1.1, 2.2, 3.3, 4.4] |
+------------------------------------------+
在 IP 地址数组开头添加元素:
SELECT array_pushfront(CAST(['192.168.1.2', '192.168.1.3'] AS ARRAY<IPV4>), CAST('192.168.1.1' AS IPV4));
+----------------------------------------------------------------------------------+
| array_pushfront(CAST(['192.168.1.2', '192.168.1.3'] AS ARRAY<IPV4>), CAST('192.168.1.1' AS IPV4)) |
+----------------------------------------------------------------------------------+
| ["192.168.1.1", "192.168.1.2", "192.168.1.3"] |
+----------------------------------------------------------------------------------+
在嵌套数组开头添加元素:
SELECT array_pushfront([[3,4], [5,6]], [1,2]);
+------------------------------------------+
| array_pushfront([[3,4], [5,6]], [1,2]) |
+------------------------------------------+
| [[1, 2], [3, 4], [5, 6]] |
+------------------------------------------+
在 MAP 数组开头添加元素:
SELECT array_pushfront([{'b':2}, {'c':3}], {'a':1});
+----------------------------------------------+
| array_pushfront([{'b':2}, {'c':3}], {'a':1}) |
+----------------------------------------------+
| [{"a":1}, {"b":2}, {"c":3}] |
+----------------------------------------------+
在 STRUCT 数组开头添加元素:
SELECT array_pushfront(array(named_struct('name','Bob','age',30), named_struct('name','Charlie','age',40)), named_struct('name','Alice','age',20));
+-------------------------------------------------------------------------------------------------------------------------------------------+
| array_pushfront(array(named_struct('name','Bob','age',30), named_struct('name','Charlie','age',40)), named_struct('name','Alice','age',20)) |
+-------------------------------------------------------------------------------------------------------------------------------------------+
| [{"name":"Alice", "age":20}, {"name":"Bob", "age":30}, {"name":"Charlie", "age":40}] |
+-------------------------------------------------------------------------------------------------------------------------------------------+
参数数量错误会报错:
SELECT array_pushfront([1,2,3]);
ERROR 1105 (HY000): errCode = 2, detailMessage: Can not found function 'array_pushfront' which has 1 arity. Candidate functions are: [array_pushfront(Expression, Expression)]
传入非数组类型时会报错:
SELECT array_pushfront('not_an_array', 1);
ERROR 1105 (HY000): errCode = 2, detailMessage: Can not find the compatibility function signature: array_pushfront(VARCHAR(12), TINYINT)
Keywords
ARRAY, PUSHFRONT, ARRAY_PUSHFRONT