Compartilhar via


Cláusula TABLESAMPLE

Aplica-se a:marca de seleção positiva Databricks SQL marca de seleção positiva Databricks Runtime

A instrução TABLESAMPLE é usada para fazer a amostragem da relação.

Sintaxe

TABLESAMPLE ( { percentage PERCENT ) |
                num_rows ROWS |
                BUCKET fraction OUT OF total } )
            [ REPEATABLE ( seed ) ]

Parâmetros

  • percentage PERCENT

    Uma constante percentage INTEGER ou DECIMAL entre 0 e 100 especificando qual o percentual das linhas da tabela a ser amostrado.

  • num_rows ROWS

    Uma expressão num_rows INTEGER positiva constante especificando um número absoluto de linhas de todas as linhas a serem amostradas.

  • BUCKET fraction OUT OF total

    Uma constante fraction INTEGER especificando a parte da constante total INTEGER a ser amostrada.

  • REPEATABLE ( seed )

    Aplica-se a:verificação marcada como sim Databricks SQL marca de seleção positiva Databricks Runtime 11.3 LTS e versões superiores

    Uma constante INTEGER positiva opcional seed, usada para sempre produzir o mesmo conjunto de linhas. Use essa cláusula quando quiser reemitir a consulta várias vezes e esperar o mesmo conjunto de linhas amostradas.

Observação

  • TABLESAMPLE retorna o número aproximado de linhas ou fração solicitada.
  • Sempre use TABLESAMPLE (percent PERCENT) se a aleatoriedade for importante. TABLESAMPLE (num_rows ROWS) is não é uma simples amostra aleatória, mas é implementada usando LIMIT.

Exemplos

> CREATE TEMPORARY VIEW test(id, name) AS
  VALUES ( 1, 'Lisa'),
         ( 2, 'Mary'),
         ( 3, 'Evan'),
         ( 4, 'Fred'),
         ( 5, 'Alex'),
         ( 6, 'Mark'),
         ( 7, 'Lily'),
         ( 8, 'Lucy'),
         ( 9, 'Eric'),
         (10, 'Adam');
> SELECT * FROM test;
  5 Alex
  8 Lucy
  2 Mary
  4 Fred
  1 Lisa
  9 Eric
 10 Adam
  6 Mark
  7 Lily
  3 Evan

> SELECT * FROM test TABLESAMPLE (30 PERCENT) REPEATABLE (123);
  1     Lisa
  2     Mary
  3     Evan
  5     Alex
  8     Lucy

> SELECT * FROM test TABLESAMPLE (5 ROWS);
  5 Alex
  8 Lucy
  2 Mary
  4 Fred
  1 Lisa

> SELECT * FROM test TABLESAMPLE (BUCKET 4 OUT OF 10);
  8 Lucy
  2 Mary
  9 Eric
  6 Mark