Podupiti u SQL-u su, u suštini, upiti unutar drugih SQL upita. Oni omogućavaju izvođenje složenijih analiza i operacija nad podacima, dajući vam mogućnost da izdvojite, filtrirate ili uporedite podatke koji zavise od rezultata drugog upita.
Definicija i svrha podupita:
Podupit je SQL upit unutar drugog SQL upita. Glavna svrha podupita je da omogući analizu podataka na više nivoa, dajući vam fleksibilnost da koristite rezultate jednog upita kao ulazne podatke za drugi.
Koristi podupita:
- Omogućavaju izvođenje složenih uslova filtriranja.
- Pomažu u izvođenju analiza koje zavise od podataka iz drugih delova baze.
- Smanjuju potrebu za privremenim tabelama.
Sintaksa i struktura:
Osnovna sintaksa podupita je:
SQL code
SELECT kolona1 FROM tabela1 WHERE kolona2 (operator) (SELECT kolona3 FROM tabela2 WHERE uslov);
Vrste podupita:
- Skalarni podupiti: Vraćaju tačno jednu vrednost (jedan red i jedna kolona).
- Podupiti sa jednim redom: Vraćaju jedan red sa više kolona.
- Podupiti sa više redova: Vraćaju više redova, koji se mogu koristiti sa operatorima kao što su IN, ANY, ALL.
Kako pisati podupite:
U WHERE klauzuli: Za filtriranje redova glavnog upita.
U FROM klauzuli: Podupiti mogu biti izvori podataka kao i tabele.
U SELECT klauzuli: Za izračunavanje vrednosti koje zavise od podataka iz drugih tabela.
Primeri:
Odaberite sve zaposlene koji rade u odeljenju sa više od 10 zaposlenih.
SQL code
SELECT ime FROM zaposleni WHERE odeljenjeID IN (SELECT odeljenjeID FROM odeljenja WHERE brojZaposlenih > 10);
Odaberite odeljenje sa najvećim brojem zaposlenih.
SQL code
SELECT odeljenjeID, brojZaposlenih FROM odeljenja WHERE brojZaposlenih = (SELECT MAX(brojZaposlenih) FROM odeljenja);
Česte greške i kako ih izbeći:
- Korišćenje podupita kada bi JOIN bio efikasniji.
- Neoptimalno korišćenje indeksa, što usporava izvođenje.
- Zaboravljanje da podupiti sa više redova zahtevaju operatori kao što su IN, ANY, ili ALL.
Najbolje prakse za optimizaciju:
- Koristite EXISTS umesto IN kada proveravate postojanje, jer je često brže.
- Ograničite upotrebu podupita samo kada je to zaista potrebno.
- Razmislite o korišćenju JOIN-a umesto podupita za bolju performansu kada je to moguće.
© Sva prava pridržana, Kompjuter biblioteka, Beograd, Obalskih radnika 4a, Telefon: +381 11 252 0 272 |
||