Skip to content
Blog

List functions

List functions are used to create and manipulate lists and/or arrays. Arrays are a special case of lists, where the length is fixed. The following list functions have been implemented.

FunctionDescriptionExampleResult
list_creation(arg1, arg2, arg3..)creates a LIST containing the argument valueslist_creation(1,2,3,4,5,56,2)[1,2,3,4,5,56,2]
size(list)returns the size of the listsize([1,2,3])3
list_extract(list, index)extracts the i-th (1-based index) value from the listlist_extract([1,2,3], 2)2
list_element(list, index)alias of list_extractlist_element([7,234,3], 1)7
list_concat(list1, list2)concatenates two listslist_concat([7,234,3], [1,3])[7,234,3,1,3]
list_cat(list1, list2)alias of list_concatlist_cat(['7','3'], ['1'])['7','3','1']
array_concat(list1, list2)alias of list_concatarray_concat([['7','2'],['3']], [['1']])[['7','2'],['3'],['1']]
array_cat(list1, list2)alias of list_concatarray_cat([4.23,5.25], [4.1])[4.23,5.25,4.1]
list_append(list, element)appends the element to listlist_append([3,5,9],4)[3,5,9,4]
array_append(list, element)alias of list_appendarray_append([2,1],3)[2,1,3]
array_push_back(list, element)alias of list_appendarray_push_back([3,6],4)[3,6,4]
list_prepend(list, element)prepends the element to listlist_prepend([3,6],4)[4,3,6]
array_prepend(list, element)alias of list_prependarray_prepend([3,6],4)[4,3,6]
array_push_front(list, element)alias of list_prependarray_push_front([1,2],3)[3,1,2]
list_position(list, element)returns the position of element in the listlist_position([3,4,5], 5)3
list_indexof(list, element)alias of list_positionlist_indexof([3,4,5], 5)3
array_position(list, element)alias of list_positionarray_position([3,4,5], 5)3
array_indexof(list, element)alias of list_positionarray_indexof([3,4,5], 5)3
list_contains(list, element)returns true if the list contains the elementlist_contains([3,4,5], 5)true
list_has(list, element)alias of list_containslist_has([3,4,5], 5)true
array_contains(list, element)alias of list_containsarray_contains([3,4,5], 5)true
array_has(list, element)alias of list_containsarray_has([3,4,5], 5)true
list_slice(list, begin, end)extracts a sub-list using slice conventions and negative values are accepted.list_slice([3,4,5], 2, 3)[4]
array_slice(list, begin, end)alias of list_slicearray_slice([6,7,1], 1, 3)[6,7]
list_reverse(list)reverse list elementslist_reverse([1,2,3])[3,2,1]
list_sort(list)sorts the elements of the list. More configurations available herelist_sort([3,10,4])[3,4,10]
list_reverse_sort(list)alias of list_sort(list, 'DESC')list_reverse_sort([3,10,4])[10,4,3]
list_sum(list)sums the elements of the list.list_sum(1,2,3)6
list_product(list)multiply elements of the list.list_product([1, 2, 3])6
list_distinct(list)removes NULLs and duplicate values from the list.list_distinct(3,3,3,NULL)[3]
list_unique(list)counts number of unique elements of the list. NULLs are ignored.list_unique(3,3,3,NULL)1
list_any_value(list)returns the first non-NULL value of the listlist_any_value(NULL, 'a', NULL)'a'
list_to_string(list, separator)converts a list to a string separated by the given separatorlist_to_string([1,2,3], '..' )'1..2..3'
range(start, stop)returns a list of values from start to stop. Specify the step as shown hererange(1,3)[1,2,3]
list_transform(list, lambda)returns a list by applying lambda function to each element of input listlist_transform([1,2,3], x->x+1)[2,3,4]
list_filter(list, lambda)returns list containing elements whose lambda function result is truelist_filter([1,2,3], x->x>1)[2,3]
list_reduce(list, lambda)returns single value by applying the lambda function on a running result and the next list element.list_reduce([1,2,3], (x,y)->x+y)6
list_has_all(list, sub-list)returns true if all elements of sub-list exist in list.list_has_all([5, 7, 2], [5, 2])true

For functions that specifically work with ARRAY data types, refer to the Array functions section.

LIST_SORT

LIST_SORT takes can be configured to sort in ascending or descending order as well as whether NULL values should be put at the beginning or at the end of the list. By default, LIST_SORT will sort in ascending order and put NULL values at first. User can change sort order with ASC or DESC key word as the second argument and change NULL values position with NULLS FIRST or NULLS LAST as the third argument.

By default, NULLs are put at the beginning of the list when sorting in descending order.

RETURN list_sort([3,10, NULL, 4], 'DESC') AS result;

Output:

-------------
| result |
-------------
| [,10,4,3] |
-------------

NULLS LAST

In certain cases, having the NULLs at the end of the returned is useful. This can be achieved by specifying NULLS LAST as the third argument.

RETURN list_sort([3,10, NULL, 4], 'DESC', 'NULLS LAST') AS result;

Output:

-------------
| result |
-------------
| [10,4,3,] |
-------------

RANGE

range(start, stop) returns a list of value from start to stop. Both ends are inclusive.

RETURN range(1,3);
--------------
| RANGE(1,3) |
--------------
| [1,2,3] |
--------------

range(start, stop, step) returns a list of value from start to stop with the given step. Both ends are inclusive.

RETURN range(1,10,2);
-----------------
| RANGE(1,10,2) |
-----------------
| [1,3,5,7,9] |
-----------------

COALESCE and IFNULL

COALESCE and IFNULL functions are used to return the first non-NULL value from the list of elements. The only difference is that COALESCE can take more than two arguments.

RETURN coalesce(NULL, 'a', NULL) AS result;

Output:

-----------
| result |
-----------
| 'a' |
-----------
RETURN ifnull(NULL, 'a') AS result;

Output:

-----------
| result |
-----------
| 'a' |
-----------