Выбирает последнее встреченное значение, аналогично anyLast, но может принимать NULL. В основном его следует использовать с Оконными Функциями. Без Оконных Функций результат будет случайным, если исходный поток не упорядочен.
examples
CREATE TABLE test_data
(
a Int64,
b Nullable(Int64)
)
ENGINE = Memory;
INSERT INTO test_data (a, b) Values (1,null), (2,3), (4, 5), (6,null)
example1
Значение NULL игнорируется по умолчанию.
select last_value(b) from test_data
┌─last_value_ignore_nulls(b)─┐
│ 5 │
└────────────────────────────┘
example2
Значение NULL игнорируется.
select last_value(b) ignore nulls from test_data
┌─last_value_ignore_nulls(b)─┐
│ 5 │
└────────────────────────────┘
example3
Значение NULL принимается.
select last_value(b) respect nulls from test_data
┌─last_value_respect_nulls(b)─┐
│ ᴺᵁᴸᴸ │
└─────────────────────────────┘
example4
Стабилизированный результат с использованием подзапроса с ORDER BY.
SELECT
last_value_respect_nulls(b),
last_value(b)
FROM
(
SELECT *
FROM test_data
ORDER BY a ASC
)
┌─last_value_respect_nulls(b)─┬─last_value(b)─┐
│ ᴺᵁᴸᴸ │ 5 │
└─────────────────────────────┴───────────────┘