Pular para o conteúdo principal
A função de tabela Values permite criar um armazenamento temporário que preenche colunas com valores. Ela é útil para testes rápidos ou para gerar dados de exemplo.
Values é uma função que não diferencia maiúsculas de minúsculas. Ou seja, tanto VALUES quanto values são válidos.

Sintaxe

A sintaxe básica da função de tabela VALUES é:
VALUES([structure,] values...)
Geralmente é usado como:
VALUES(
    ['column1_name Type1, column2_name Type2, ...'],
    (value1_row1, value2_row1, ...),
    (value1_row2, value2_row2, ...),
    ...
)

Argumentos

  • column1_name Type1, ... (opcional). String que especifica os nomes e os tipos das colunas. Se esse argumento for omitido, as colunas serão nomeadas como c1, c2 etc.
  • (value1_row1, value2_row1). Tuplas contendo valores de qualquer tipo.
Tuplas separadas por vírgula também podem ser substituídas por valores individuais. Nesse caso, cada valor é considerado uma nova linha. Consulte a seção de exemplos para mais detalhes.

Valor retornado

  • Retorna uma tabela temporária com os valores fornecidos.

Exemplos

Query
SELECT *
FROM VALUES(
    'person String, place String',
    ('Noah', 'Paris'),
    ('Emma', 'Tokyo'),
    ('Liam', 'Sydney'),
    ('Olivia', 'Berlin'),
    ('Ilya', 'London'),
    ('Sophia', 'London'),
    ('Jackson', 'Madrid'),
    ('Alexey', 'Amsterdam'),
    ('Mason', 'Venice'),
    ('Isabella', 'Prague')
)
Response
    ┌─person───┬─place─────┐
 1. │ Noah     │ Paris     │
 2. │ Emma     │ Tokyo     │
 3. │ Liam     │ Sydney    │
 4. │ Olivia   │ Berlin    │
 5. │ Ilya     │ London    │
 6. │ Sophia   │ London    │
 7. │ Jackson  │ Madrid    │
 8. │ Alexey   │ Amsterdam │
 9. │ Mason    │ Venice    │
10. │ Isabella │ Prague    │
    └──────────┴───────────┘
VALUES também pode ser usado com valores individuais em vez de tuplas. Por exemplo:
Query
SELECT *
FROM VALUES(
    'person String',
    'Noah',
    'Emma',
    'Liam',
    'Olivia',
    'Ilya',
    'Sophia',
    'Jackson',
    'Alexey',
    'Mason',
    'Isabella'
)
Response
    ┌─person───┐
 1. │ Noah     │
 2. │ Emma     │
 3. │ Liam     │
 4. │ Olivia   │
 5. │ Ilya     │
 6. │ Sophia   │
 7. │ Jackson  │
 8. │ Alexey   │
 9. │ Mason    │
10. │ Isabella │
    └──────────┘
Ou sem fornecer uma especificação de linha ('column1_name Type1, column2_name Type2, ...' na sintaxe), caso em que os nomes das colunas são atribuídos automaticamente. Por exemplo:
Query
-- tuplas como valores
SELECT *
FROM VALUES(
    ('Noah', 'Paris'),
    ('Emma', 'Tokyo'),
    ('Liam', 'Sydney'),
    ('Olivia', 'Berlin'),
    ('Ilya', 'London'),
    ('Sophia', 'London'),
    ('Jackson', 'Madrid'),
    ('Alexey', 'Amsterdam'),
    ('Mason', 'Venice'),
    ('Isabella', 'Prague')
)
Response
    ┌─c1───────┬─c2────────┐
 1. │ Noah     │ Paris     │
 2. │ Emma     │ Tokyo     │
 3. │ Liam     │ Sydney    │
 4. │ Olivia   │ Berlin    │
 5. │ Ilya     │ London    │
 6. │ Sophia   │ London    │
 7. │ Jackson  │ Madrid    │
 8. │ Alexey   │ Amsterdam │
 9. │ Mason    │ Venice    │
10. │ Isabella │ Prague    │
    └──────────┴───────────┘
Query
-- valores únicos
SELECT *
FROM VALUES(
    'Noah',
    'Emma',
    'Liam',
    'Olivia',
    'Ilya',
    'Sophia',
    'Jackson',
    'Alexey',
    'Mason',
    'Isabella'
)
Response
    ┌─c1───────┐
 1. │ Noah     │
 2. │ Emma     │
 3. │ Liam     │
 4. │ Olivia   │
 5. │ Ilya     │
 6. │ Sophia   │
 7. │ Jackson  │
 8. │ Alexey   │
 9. │ Mason    │
10. │ Isabella │
    └──────────┘

Cláusula VALUES do padrão SQL

A partir da versão 26.3, o ClickHouse também oferece suporte à cláusula VALUES padrão SQL como uma expressão de tabela em FROM, como ocorre no PostgreSQL, MySQL, DuckDB e SQL Server. Essa sintaxe é reescrita internamente para usar a função de tabela values descrita acima.
Query
SELECT * FROM (VALUES (1, 'a'), (2, 'b'), (3, 'c')) AS t(id, val);
Response
┌─id─┬─val─┐
│  1 │ a   │
│  2 │ b   │
│  3 │ c   │
└────┴─────┘
Pode ser usado em CTEs:
Query
WITH cte AS (SELECT * FROM (VALUES (1, 'one'), (2, 'two')) AS t(id, name))
SELECT * FROM cte;
E nas junções:
Query
SELECT t1.id, t1.val, t2.val2
FROM (VALUES (1, 'a'), (2, 'b')) AS t1(id, val)
JOIN (VALUES (1, 'x'), (2, 'y')) AS t2(id, val2) ON t1.id = t2.id;
Os aliases de coluna após AS t(col1, col2, ...) seguem a sintaxe SQL padrão para nomear as colunas de tabelas derivadas. Se forem omitidos, as colunas serão nomeadas c1, c2 etc.

Veja também

Última modificação em 10 de junho de 2026