ARRAY_AVG
Description
Get the average of all elements in an array (NULL
values are skipped).
When the array is empty or all elements in the array are NULL
values, the function returns NULL
.
Syntax
ARRAY_AVG(<arr>)
Parameters
Parameter | Description |
---|---|
<arr> | The array to calculate the average values from |
Return Value
Returns a constant. Special cases:
NULL
values in the array will be skipped.- Strings and varchar in the array will be skipped.
Example
create table array_type_table(
k1 INT,
k2 Array<int>
)
duplicate key (k1)
distributed by hash(k1) buckets 1
properties(
'replication_num' = '1'
);
insert into array_type_table values (0, []), (1, [NULL]), (2, [1, 2, 3]), (3, [1, NULL, 3]);
select k2, array_avg(k2) from array_type_table;
+--------------+-----------------+
| k2 | array_avg(`k2`) |
+--------------+-----------------+
| [] | NULL |
| [NULL] | NULL |
| [1, 2, 3] | 2 |
| [1, NULL, 3] | 2 |
+--------------+-----------------+
select array_avg(['test',2,1,null]);
+------------------------------------------------------------+
| array_avg(cast(['test', '2', '1', NULL] as ARRAY<DOUBLE>)) |
+------------------------------------------------------------+
| 1.5 |
+------------------------------------------------------------+