LIMIT klauzula
Dotyczy: Databricks SQL Databricks Runtime
Ogranicza liczbę wierszy zwracanych przez zapytanie. Ogólnie rzecz biorąc, ta klauzula jest używana w połączeniu z ORDER BY w celu zapewnienia, że wyniki są deterministyczne.
Składnia
LIMIT { ALL | integer_expression }
Parameters
ALL
Jeśli zostanie określony, zapytanie zwraca wszystkie wiersze. Innymi słowy, jeśli ta opcja zostanie określona, żadna limit nie zostanie zastosowana.
integer_expression
Wyrażenie literału zwracające liczbę całkowitą.
Przykłady
> CREATE TEMP VIEW person (name, age)
AS VALUES ('Zen Hui', 25),
('Anil B' , 18),
('Shone S', 16),
('Mike A' , 25),
('John A' , 18),
('Jack N' , 16);
-- Select the first two rows.
> SELECT name, age FROM person ORDER BY name LIMIT 2;
Anil B 18
Jack N 16
-- Select the 4th and 5th rows by alphabetical order.
> SELECT name, age FROM person ORDER BY name LIMIT 2 OFFSET 3;
Mike A 25
Shone S 16
-- Specifying ALL option on LIMIT returns all the rows.
> SELECT name, age FROM person ORDER BY name LIMIT ALL;
Anil B 18
Jack N 16
John A 18
Mike A 25
Shone S 16
Zen Hui 25
-- A function expression as an input to LIMIT.
> SELECT name, age FROM person ORDER BY name LIMIT length('SPARK');
Anil B 18
Jack N 16
John A 18
Mike A 25
Shone S 16
-- A non-literal expression as an input to LIMIT is not allowed.
SELECT name, age FROM person ORDER BY name LIMIT length(name);
Error: The limit expression must evaluate to a constant value