PostgreSQL - klauzula LIMIT
PostgreSQL LIMIT klauzula służy do ograniczenia ilości danych zwracanych przez instrukcję SELECT.
Składnia
Podstawowa składnia instrukcji SELECT z klauzulą LIMIT jest następująca -
SELECT column1, column2, columnN
FROM table_name
LIMIT [no of rows]
Poniżej przedstawiono składnię klauzuli LIMIT, gdy jest ona używana razem z klauzulą OFFSET -
SELECT column1, column2, columnN
FROM table_name
LIMIT [no of rows] OFFSET [row num]
LIMIT i OFFSET umożliwiają pobranie tylko części wierszy, które są generowane przez pozostałą część zapytania.
Przykład
Rozważ poniższą tabelę FIRMA zawierająca rekordy -
# select * from COMPANY;
id | name | age | address | salary
----+-------+-----+-----------+--------
1 | Paul | 32 | California| 20000
2 | Allen | 25 | Texas | 15000
3 | Teddy | 23 | Norway | 20000
4 | Mark | 25 | Rich-Mond | 65000
5 | David | 27 | Texas | 85000
6 | Kim | 22 | South-Hall| 45000
7 | James | 24 | Houston | 10000
(7 rows)
Poniżej znajduje się przykład, który ogranicza wiersz w tabeli zgodnie z liczbą wierszy, które chcesz pobrać z tabeli -
testdb=# SELECT * FROM COMPANY LIMIT 4;
Dałoby to następujący wynik -
id | name | age | address | salary
----+-------+-----+-------------+--------
1 | Paul | 32 | California | 20000
2 | Allen | 25 | Texas | 15000
3 | Teddy | 23 | Norway | 20000
4 | Mark | 25 | Rich-Mond | 65000
(4 rows)
Jednak w pewnych sytuacjach może być konieczne pobranie zestawu rekordów z określonego przesunięcia. Oto przykład, który wybiera trzy rekordy zaczynając od trzeciej pozycji -
testdb=# SELECT * FROM COMPANY LIMIT 3 OFFSET 2;
Dałoby to następujący wynik -
id | name | age | address | salary
----+-------+-----+-----------+--------
3 | Teddy | 23 | Norway | 20000
4 | Mark | 25 | Rich-Mond | 65000
5 | David | 27 | Texas | 85000
(3 rows)