blob: 0f52720907131ce195b8aabb6db0eb6895423727 [file] [log] [blame] [view]
---
{
"title": "ARRAY_ENUMERATE",
"language": "en",
"description": "Returns the position index (starting from 1) for each element in the array."
}
---
## array_enumerate
<version since="2.0.0">
</version>
## Description
Returns the position index (starting from 1) for each element in the array. The function generates corresponding position numbers for each element in the array.
## Syntax
```sql
array_enumerate(ARRAY<T> arr)
```
### Parameters
- `arr`ARRAY<T> type, the array for which to generate position indices. Supports column names or constant values.
**Supported types for T:**
- Numeric types: TINYINT, SMALLINT, INT, BIGINT, LARGEINT, FLOAT, DOUBLE, DECIMAL
- String types: CHAR, VARCHAR, STRING
- Date and time types: DATE, DATETIME, DATEV2, DATETIMEV2
- Boolean type: BOOLEAN
- IP types: IPV4, IPV6
- Complex types: ARRAY, MAP, STRUCT
### Return Value
Return type: ARRAY<BIGINT>
Return value meaning:
- Returns a new array with the same length as the input array, where each position contains the position index (starting from 1) of the corresponding element in the array
- NULL: if the input array is NULL
Usage notes:
- The function generates position indices for each element in the array, starting from 1 and incrementing
- Empty arrays return empty arrays, NULL arrays return NULL
- For null values in array elements: null elements also generate corresponding position indices
### Examples
**Query Examples:**
Generate position indices for an array:
```sql
SELECT array_enumerate([1, 2, 1, 4, 5]);
+----------------------------------+
| array_enumerate([1, 2, 1, 4, 5]) |
+----------------------------------+
| [1, 2, 3, 4, 5] |
+----------------------------------+
```
Empty array returns empty array:
```sql
SELECT array_enumerate([]);
+----------------------+
| array_enumerate([]) |
+----------------------+
| [] |
+----------------------+
```
Array containing null values, null elements also generate position indices:
```sql
SELECT array_enumerate([1, null, 3, null, 5]);
+--------------------------------------------+
| array_enumerate([1, null, 3, null, 5]) |
+--------------------------------------------+
| [1, 2, 3, 4, 5] |
+--------------------------------------------+
```
Complex type examples:
Nested array types:
```sql
SELECT array_enumerate([[1,2],[3,4],[5,6]]);
+----------------------------------------+
| array_enumerate([[1,2],[3,4],[5,6]]) |
+----------------------------------------+
| [1, 2, 3] |
+----------------------------------------+
```
Map types:
```sql
SELECT array_enumerate([{'k':1},{'k':2},{'k':3}]);
+----------------------------------------------+
| array_enumerate([{'k':1},{'k':2},{'k':3}]) |
+----------------------------------------------+
| [1, 2, 3] |
+----------------------------------------------+
```
Struct types:
```sql
SELECT array_enumerate(array(named_struct('name','Alice','age',20),named_struct('name','Bob','age',30)));
+----------------------------------------------------------------------------------------+
| array_enumerate(array(named_struct('name','Alice','age',20),named_struct('name','Bob','age',30))) |
+----------------------------------------------------------------------------------------+
| [1, 2] |
+----------------------------------------------------------------------------------------+
```
Error when parameter count is wrong:
```sql
SELECT array_enumerate([1,2,3], [4,5,6]);
ERROR 1105 (HY000): errCode = 2, detailMessage = Can not found function 'array_enumerate' which has 2 arity. Candidate functions are: [array_enumerate(Expression)]
```
Error when passing non-array type:
```sql
SELECT array_enumerate('not_an_array');
ERROR 1105 (HY000): errCode = 2, detailMessage = Can not find the compatibility function signature: array_enumerate(VARCHAR(12))
```
### Keywords
ARRAY, ENUMERATE, ARRAY_ENUMERATE