W tym wpisie chciałbym przedstawić operator UNION(ALL). Operator ten pomaga w spięciu w jedno zapytanie min. dwóch klauzul SELECT. Haczykiem jest to, aby zapytania miało tyle samo tabel oraz dane te muszą być tych samych typów.
PostgreSQL Union(ALL) Nieco Teorii…
Schemat użycia UNION(ALL) jest prosty.
1 2 3 4 5 6 7 8 9 10 11 12 13 |
SELECT kolumna_1, kolumna_2 FROM tabela_1 UNION SELECT kolumna_1, kolumna_2 FROM tabela_2; |
Tak jak wspomniałem UNION(ALL) łączy min. dwa różne zapytania SELECT i pokazuje jeden wynik.
UNION od UNION ALL różni się tym, że ten pierwszy pokazuje wyniki bez powtórzeń, natomiast ten drugi pokaże również powtórzenia wyników. Oczywiście można zastosować ORDER BY, aby posortować dane.
Przykłady, Przykłady…
W tym przykładzie zobaczysz w jaki sposób wyświetlić wszystkich aktorów z tabeli actor.
W tabeli znajduje się 200 wpisów, więc zapytanie UNION powinno zwrócić również 200 wyników, ponieważ nie pojawią się tam powtórzenia.
1 2 3 |
SELECT * FROM public.actor UNION SELECT * FROM public.actor |
Natomiast UNION ALL wyświetli 400 wierszy, ponieważ nie zostaną pominięte powtórzenia. Dane zostaną wyświetlone najpierw wszystkie z pierwszego zapytania po czym powtórnie dane z drugiego zapytania.
1 2 3 |
SELECT * FROM public.actor UNION ALL SELECT * FROM public.actor |
To tyle, zapraszam na kolejny wpis, w którym opowiem nieco o klauzuli INTERSECT.
Dziękuję Ci, za poświęcony czas na przeczytanie tego artykułu. Jeśli był on dla Ciebie przydatny, to gorąco zachęcam Cię do zapisania się na mój newsletter, jeżeli jeszcze Cię tam nie ma. Proszę Cię także o “polubienie” mojego bloga na Facebooku oraz kanału na YouTube – pomoże mi to dotrzeć do nowych odbiorców. Raz w tygodniu (niedziela punkt 17.00) otrzymasz powiadomienia o nowych artykułach / projektach zanim staną się publiczne. Możesz również pozostawić całkowicie anonimowy pomysł na wpis/nagranie.
Link do formularza tutaj: https://beitadmin.pl/pomysly
Pozostaw również komentarz lub napisz do mnie wiadomość odpisuję na każdą, jeżeli Masz jakieś pytania:).