Seleciona o último valor encontrado, semelhante a anyLast, mas pode aceitar NULL.
Em geral, deve ser usado com funções de janela.
Sem funções de janela, o resultado será aleatório se o fluxo de dados não estiver ordenado.
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)
O valor NULL é ignorado por padrão.
SELECT last_value(b) FROM test_data
┌─last_value_ignore_nulls(b)─┐
│ 5 │
└────────────────────────────┘
O valor NULL é ignorado.
SELECT last_value(b) ignore nulls FROM test_data
┌─last_value_ignore_nulls(b)─┐
│ 5 │
└────────────────────────────┘
O valor NULL é aceito.
SELECT last_value(b) respect nulls FROM test_data
┌─last_value_respect_nulls(b)─┐
│ ᴺᵁᴸᴸ │
└─────────────────────────────┘
Resultado estável usando a subconsulta com 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 │
└─────────────────────────────┴───────────────┘
Última modificação em 10 de junho de 2026