Napredni SQL upiti su ono što te odvaja od početnika...
Napredni SQL Upiti: Vodič za Kompleksne Operacije








Uvod u napredne SQL upite
Dosad si radio samo sa osnovnim SELECT upitima iz jedne tabele, ali u stvarnim bazama podataka informacije su skoro uvek raspoređene u više povezanih tabela. Tu dolaze napredni SQL upiti koji ti omogućavaju da kombinuješ podatke iz različitih tabela i praviš ozbiljne analize.
Najvažniji pojmovi koje moraš da razumeš su JOIN operacije (za spajanje tabela), agregatne funkcije kao što su COUNT() i AVG(), te GROUP BY za grupisanje podataka. Tu su i podupiti - upiti unutar upita koji ti omogućavaju naprednije filtriranje.
💡 Zapamti: Osnova za spajanje tabela su primarni ključ (PK) u jednoj tabeli i strani ključ (FK) u drugoj - to je veza koja omogućava kombinovanje podataka.

Tipovi JOIN operacija
INNER JOIN je najčešći i najvažniji tip spajanja - vraća samo one redove gde se vrednosti poklapaju u obe tabele. Sintaksa je jednostavna: SELECT kolone FROM tabela1 INNER JOIN tabela2 ON tabela1.pk = tabela2.fk.
LEFT JOIN je super kada želiš da vidiš sve entitete iz leve tabele, bez obzira da li imaju parnjaka u desnoj. Na primer, sve učenike čak i one bez ijedne ocene - kolone iz desne tabele će biti NULL ako nema poklapanja.
RIGHT JOIN radi suprotno od LEFT JOIN-a, dok se FULL OUTER JOIN retko koristi na testovima jer kombinuje LEFT i RIGHT JOIN. Venovi dijagrami odlično prikazuju kako ovi JOIN-ovi funkcionišu.
💡 Saveti: Uvek koristi aliase (AS) za tabele kod JOIN-ova -
FROM Ucenici AS uje mnogo čitljivije i kraće od pisanja punog naziva tabele.

Grupisanje i agregatne funkcije
GROUP BY ti omogućava da grupišeš redove koji imaju iste vrednosti u određenim kolonama, a zatim primeniš agregatne funkcije poput COUNT(), SUM(), AVG() na svaku grupu. Ovo je ključno za dobijanje statističkih podataka.
Najvažnija razlika koju moraš da zapamtiš: WHERE se izvršava pre GROUP BY, a HAVING posle GROUP BY. WHERE filtrira pojedinačne redove, dok HAVING filtrira cele grupe. U HAVING klauzuli možeš da koristiš agregatne funkcije, u WHERE ne možeš.
Podupiti su upiti unutar upita - spoljni upit koristi rezultat unutrašnjeg. Skalarni podupit vraća jednu vrednost i može se koristiti bilo gde, dok višeredni podupit vraća više redova i često se koristi sa IN, NOT IN operatorima.
💡 Ključno za ispit: Redosled izvršavanja je FROM/JOIN → WHERE → GROUP BY → HAVING → SELECT → ORDER BY. Ovo objašnjava zašto WHERE ne može da koristi agregatne funkcije!

Praktični primeri sa rešenjima
Za spajanje podataka iz tabela Ucenici i Odeljenja koristiš INNER JOIN preko zajedničke kolone OdeljenjeID: SELECT u.Ime, u.Prezime, o.NazivOdeljenja FROM Ucenici AS u INNER JOIN Odeljenja AS o ON u.OdeljenjeID = o.OdeljenjeID.
Za izračunavanje prosečne ocene po učeniku kombinuješ AVG() funkciju sa GROUP BY: SELECT u.Ime, u.Prezime, AVG(oc.Ocena) AS ProsecnaOcena FROM Ucenici AS u JOIN Ocene AS oc ON u.UcenikID = oc.UcenikID GROUP BY u.UcenikID, u.Ime, u.Prezime.
Kada trebaš da filtriraš grupe, koristiš HAVING umesto WHERE. Za predmete sa prosekom većim od 4.0: SELECT Predmet, AVG(Ocena) AS Prosek FROM Ocene GROUP BY Predmet HAVING AVG(Ocena) > 4.0.
💡 Važna napomena: Sve kolone u SELECT listi koje nisu pod agregatnom funkcijom moraju biti u GROUP BY klauzuli!

Podupiti i napredne tehnike
Podupit ti omogućava da koristiš rezultat jednog upita u drugom upitu. Na primer, za učenike iz odeljenja "IV-2": SELECT Ime, Prezime FROM Ucenici WHERE OdeljenjeID = .
Ovo je često efikasnije od JOIN-a kada ti trebaju podaci samo iz jedne tabele. Skalarni podupiti vraćaju jednu vrednost, dok višeredni rade sa IN operatorom za više rezultata.
Redosled izvršavanja SQL upita je ključan za razumevanje: FROM/JOIN → WHERE → GROUP BY → HAVING → SELECT → DISTINCT → ORDER BY → LIMIT. Iako pišeš SELECT prvi, baza ga izvršava skoro na kraju!
💡 Za ispit: Agregatne funkcije (SUM, AVG, MIN, MAX) ignorišu NULL vrednosti, ali COUNT(*) broji sve redove uključujući i NULL.

Kratak pregled za ispit
JOIN operacije: INNER JOIN spaja samo poklapanja (najvažniji), LEFT JOIN čuva sve iz leve tabele. Agregatne funkcije COUNT, SUM, AVG rade nad grupama redova koje kreira GROUP BY.
Ključna razlika: WHERE filtrira redove pre grupisanja, HAVING filtrira grupe posle agregacije. Ovo je najčešće pitanje na testu, tako da dobro zapamti!
Podupiti mogu biti skalarni (jedna vrednost) ili višeredni (više redova sa IN operatorom). NULL vrednosti su poseban slučaj - agregatne funkcije ih ignorišu, osim COUNT(*).
💡 Finalni saveti: Koristi aliase za čitljivost, zapamti redosled izvršavanja upita, i vežbaj razliku između WHERE i HAVING - to je garantovano na ispitu!

Wir dachten schon, du fragst nie...
Was ist der Knowunity KI-Begleiter?
Unser KI-Begleiter ist ein speziell für Schüler entwickeltes KI-Tool, das mehr als nur Antworten bietet. Basierend auf Millionen von Knowunity-Inhalten liefert er relevante Informationen, personalisierte Lernpläne, Quizze und Inhalte direkt im Chat und passt sich deinem individuellen Lernweg an.
Wo kann ich die Knowunity-App herunterladen?
Du kannst die App im Google Play Store und im Apple App Store herunterladen.
Ist Knowunity wirklich kostenlos?
Genau! Genieße kostenlosen Zugang zu Lerninhalten, vernetze dich mit anderen Schülern und hol dir sofortige Hilfe – alles direkt auf deinem Handy.
Beliebtester Inhalt in Informatika
9Uvod u programski jezik (npr. Python)
Upoznavanje sa programskim okruženjem, pisanjem i pokretanjem jednostavnih programa u odabranom jeziku.
Veštačka inteligencija i mašinsko učenje
Uvod u osnovne koncepte veštačke inteligencije i mašinskog učenja, kao i njihove primene u svakodnevnom životu i industriji.
Grafički prikaz podataka
Kreiranje različitih tipova grafikona (stubičasti, linijski, kružni) za jasnije i vizuelno privlačnije predstavljanje podataka.
SQL – upiti za preuzimanje podataka (SELECT)
Korišćenje SELECT naredbe sa WHERE, ORDER BY i GROUP BY klauzulama za efikasno preuzimanje i filtriranje podataka iz tabela.
Uvod u algoritme
Definisanje algoritma, razumevanje njegovih osobina i upoznavanje sa različitim načinima predstavljanja, kao što su pseudokod i dijagram toka.
CSS – responzivni dizajn (osnove)
Upoznavanje sa osnovama responzivnog dizajna i korišćenjem media queries-a za prilagođavanje izgleda veb stranice različitim veličinama ekrana.
HTML – struktura veb stranice
Učenje o naprednijim HTML oznakama, semantičkim HTML5 elementima i ugradnji multimedijalnih sadržaja za obogaćivanje veb stranica.
Digitalna reprezentacija podataka
Upoznavanje sa binarnim sistemom (bit, bajt) kao osnovom za predstavljanje svih vrsta podataka u računaru.
Kategorije softvera
Razumevanje različitih kategorija softvera, uključujući sistemski, aplikativni i uslužni softver, kao i softver otvorenog koda.
Beliebtester Inhalt
9Glagoli
Ponavljaće se poznati glagolski oblici (prezent, perfekat, futur I), a učiće se i novi oblici kao što su aorist, imperfekat, pluskvamperfekat, futur II, kao i glagolski prilozi i pridevi.
Glavni frontovi i ključne bitke
Proučavaće se najvažniji frontovi i bitke koje su obeležile Prvi svetski rat.
Rečenični članovi
Učiće se o glavnim i sporednim rečeničnim članovima (subjekat, predikat, objekat, priloške odredbe, atribut, apozicija) i njihovoj funkciji.
Glagoli
Obradićemo glagolska vremena (prezent, futur I, perfekat) i glagolske načine, kao i glagolske oblike (infinitiv, glagolski pridevi i prilozi) i glagolski vid (svršeni i nesvršeni).
Ugljovodonici
Učićete o najjednostavnijim organskim jedinjenjima – ugljovodonicima, uključujući alkane, alkene i alkine, njihove opšte formule i osnovnu nomenklaturu.
Glasovi i glasovne promene
Ponovićemo šta su glasovi i kako se dele, a zatim ćemo učiti o važnim promenama koje se dešavaju kada se glasovi nađu jedan pored drugog u rečima (npr. jednačenje suglasnika po zvučnosti i mestu tvorbe).
Stilske figure
Ponavljaće se i produbljivati znanje o stilskim figurama kao što su epitet, poređenje, metafora, personifikacija, hiperbola, onomatopeja, aliteracija i asonanca, razumevajući njihovu ulogu u tekstu.
Fonetika
Za 8. Razred
Četvorougao
Upoznavanje sa vrstama četvorouglova (paralelogram, pravougaonik, kvadrat, romb, trapez) i njihovim osnovnim svojstvima.
Findest du nicht, was du suchst? Entdecke andere Fächer.
Schüler lieben uns — und du auch.
Die App ist sehr einfach zu bedienen und gut gestaltet. Ich habe bisher alles gefunden, wonach ich gesucht habe, und konnte viel aus den Präsentationen lernen! Ich werde die App definitiv für ein Schulprojekt nutzen! Und natürlich hilft sie auch sehr als Inspiration.
Diese App ist wirklich super. Es gibt so viele Lernzettel und Hilfen [...]. Mein Problemfach ist zum Beispiel Französisch und die App hat so viele Möglichkeiten zur Hilfe. Dank dieser App habe ich mich in Französisch verbessert. Ich würde sie jedem empfehlen.
Wow, ich bin wirklich begeistert. Ich habe die App einfach mal ausprobiert, weil ich sie schon oft beworben gesehen habe und war absolut beeindruckt. Diese App ist DIE HILFE, die man für die Schule braucht und vor allem bietet sie so viele Dinge wie Übungen und Lernzettel, die mir persönlich SEHR geholfen haben.
Napredni SQL Upiti: Vodič za Kompleksne Operacije
Napredni SQL upiti su ono što te odvaja od početnika - omogućavaju ti da kombinuješ podatke iz više tabela, praviš složene kalkulacije i dobijaš prave odgovore iz baze podataka. Ovo je materijal koji ćeš definitivno imati na ispitu i koristiti...

Uvod u napredne SQL upite
Dosad si radio samo sa osnovnim SELECT upitima iz jedne tabele, ali u stvarnim bazama podataka informacije su skoro uvek raspoređene u više povezanih tabela. Tu dolaze napredni SQL upiti koji ti omogućavaju da kombinuješ podatke iz različitih tabela i praviš ozbiljne analize.
Najvažniji pojmovi koje moraš da razumeš su JOIN operacije (za spajanje tabela), agregatne funkcije kao što su COUNT() i AVG(), te GROUP BY za grupisanje podataka. Tu su i podupiti - upiti unutar upita koji ti omogućavaju naprednije filtriranje.
💡 Zapamti: Osnova za spajanje tabela su primarni ključ (PK) u jednoj tabeli i strani ključ (FK) u drugoj - to je veza koja omogućava kombinovanje podataka.

Tipovi JOIN operacija
INNER JOIN je najčešći i najvažniji tip spajanja - vraća samo one redove gde se vrednosti poklapaju u obe tabele. Sintaksa je jednostavna: SELECT kolone FROM tabela1 INNER JOIN tabela2 ON tabela1.pk = tabela2.fk.
LEFT JOIN je super kada želiš da vidiš sve entitete iz leve tabele, bez obzira da li imaju parnjaka u desnoj. Na primer, sve učenike čak i one bez ijedne ocene - kolone iz desne tabele će biti NULL ako nema poklapanja.
RIGHT JOIN radi suprotno od LEFT JOIN-a, dok se FULL OUTER JOIN retko koristi na testovima jer kombinuje LEFT i RIGHT JOIN. Venovi dijagrami odlično prikazuju kako ovi JOIN-ovi funkcionišu.
💡 Saveti: Uvek koristi aliase (AS) za tabele kod JOIN-ova -
FROM Ucenici AS uje mnogo čitljivije i kraće od pisanja punog naziva tabele.

Grupisanje i agregatne funkcije
GROUP BY ti omogućava da grupišeš redove koji imaju iste vrednosti u određenim kolonama, a zatim primeniš agregatne funkcije poput COUNT(), SUM(), AVG() na svaku grupu. Ovo je ključno za dobijanje statističkih podataka.
Najvažnija razlika koju moraš da zapamtiš: WHERE se izvršava pre GROUP BY, a HAVING posle GROUP BY. WHERE filtrira pojedinačne redove, dok HAVING filtrira cele grupe. U HAVING klauzuli možeš da koristiš agregatne funkcije, u WHERE ne možeš.
Podupiti su upiti unutar upita - spoljni upit koristi rezultat unutrašnjeg. Skalarni podupit vraća jednu vrednost i može se koristiti bilo gde, dok višeredni podupit vraća više redova i često se koristi sa IN, NOT IN operatorima.
💡 Ključno za ispit: Redosled izvršavanja je FROM/JOIN → WHERE → GROUP BY → HAVING → SELECT → ORDER BY. Ovo objašnjava zašto WHERE ne može da koristi agregatne funkcije!

Praktični primeri sa rešenjima
Za spajanje podataka iz tabela Ucenici i Odeljenja koristiš INNER JOIN preko zajedničke kolone OdeljenjeID: SELECT u.Ime, u.Prezime, o.NazivOdeljenja FROM Ucenici AS u INNER JOIN Odeljenja AS o ON u.OdeljenjeID = o.OdeljenjeID.
Za izračunavanje prosečne ocene po učeniku kombinuješ AVG() funkciju sa GROUP BY: SELECT u.Ime, u.Prezime, AVG(oc.Ocena) AS ProsecnaOcena FROM Ucenici AS u JOIN Ocene AS oc ON u.UcenikID = oc.UcenikID GROUP BY u.UcenikID, u.Ime, u.Prezime.
Kada trebaš da filtriraš grupe, koristiš HAVING umesto WHERE. Za predmete sa prosekom većim od 4.0: SELECT Predmet, AVG(Ocena) AS Prosek FROM Ocene GROUP BY Predmet HAVING AVG(Ocena) > 4.0.
💡 Važna napomena: Sve kolone u SELECT listi koje nisu pod agregatnom funkcijom moraju biti u GROUP BY klauzuli!

Podupiti i napredne tehnike
Podupit ti omogućava da koristiš rezultat jednog upita u drugom upitu. Na primer, za učenike iz odeljenja "IV-2": SELECT Ime, Prezime FROM Ucenici WHERE OdeljenjeID = .
Ovo je često efikasnije od JOIN-a kada ti trebaju podaci samo iz jedne tabele. Skalarni podupiti vraćaju jednu vrednost, dok višeredni rade sa IN operatorom za više rezultata.
Redosled izvršavanja SQL upita je ključan za razumevanje: FROM/JOIN → WHERE → GROUP BY → HAVING → SELECT → DISTINCT → ORDER BY → LIMIT. Iako pišeš SELECT prvi, baza ga izvršava skoro na kraju!
💡 Za ispit: Agregatne funkcije (SUM, AVG, MIN, MAX) ignorišu NULL vrednosti, ali COUNT(*) broji sve redove uključujući i NULL.

Kratak pregled za ispit
JOIN operacije: INNER JOIN spaja samo poklapanja (najvažniji), LEFT JOIN čuva sve iz leve tabele. Agregatne funkcije COUNT, SUM, AVG rade nad grupama redova koje kreira GROUP BY.
Ključna razlika: WHERE filtrira redove pre grupisanja, HAVING filtrira grupe posle agregacije. Ovo je najčešće pitanje na testu, tako da dobro zapamti!
Podupiti mogu biti skalarni (jedna vrednost) ili višeredni (više redova sa IN operatorom). NULL vrednosti su poseban slučaj - agregatne funkcije ih ignorišu, osim COUNT(*).
💡 Finalni saveti: Koristi aliase za čitljivost, zapamti redosled izvršavanja upita, i vežbaj razliku između WHERE i HAVING - to je garantovano na ispitu!

Wir dachten schon, du fragst nie...
Was ist der Knowunity KI-Begleiter?
Unser KI-Begleiter ist ein speziell für Schüler entwickeltes KI-Tool, das mehr als nur Antworten bietet. Basierend auf Millionen von Knowunity-Inhalten liefert er relevante Informationen, personalisierte Lernpläne, Quizze und Inhalte direkt im Chat und passt sich deinem individuellen Lernweg an.
Wo kann ich die Knowunity-App herunterladen?
Du kannst die App im Google Play Store und im Apple App Store herunterladen.
Ist Knowunity wirklich kostenlos?
Genau! Genieße kostenlosen Zugang zu Lerninhalten, vernetze dich mit anderen Schülern und hol dir sofortige Hilfe – alles direkt auf deinem Handy.
Beliebtester Inhalt in Informatika
9Uvod u programski jezik (npr. Python)
Upoznavanje sa programskim okruženjem, pisanjem i pokretanjem jednostavnih programa u odabranom jeziku.
Veštačka inteligencija i mašinsko učenje
Uvod u osnovne koncepte veštačke inteligencije i mašinskog učenja, kao i njihove primene u svakodnevnom životu i industriji.
Grafički prikaz podataka
Kreiranje različitih tipova grafikona (stubičasti, linijski, kružni) za jasnije i vizuelno privlačnije predstavljanje podataka.
SQL – upiti za preuzimanje podataka (SELECT)
Korišćenje SELECT naredbe sa WHERE, ORDER BY i GROUP BY klauzulama za efikasno preuzimanje i filtriranje podataka iz tabela.
Uvod u algoritme
Definisanje algoritma, razumevanje njegovih osobina i upoznavanje sa različitim načinima predstavljanja, kao što su pseudokod i dijagram toka.
CSS – responzivni dizajn (osnove)
Upoznavanje sa osnovama responzivnog dizajna i korišćenjem media queries-a za prilagođavanje izgleda veb stranice različitim veličinama ekrana.
HTML – struktura veb stranice
Učenje o naprednijim HTML oznakama, semantičkim HTML5 elementima i ugradnji multimedijalnih sadržaja za obogaćivanje veb stranica.
Digitalna reprezentacija podataka
Upoznavanje sa binarnim sistemom (bit, bajt) kao osnovom za predstavljanje svih vrsta podataka u računaru.
Kategorije softvera
Razumevanje različitih kategorija softvera, uključujući sistemski, aplikativni i uslužni softver, kao i softver otvorenog koda.
Beliebtester Inhalt
9Glagoli
Ponavljaće se poznati glagolski oblici (prezent, perfekat, futur I), a učiće se i novi oblici kao što su aorist, imperfekat, pluskvamperfekat, futur II, kao i glagolski prilozi i pridevi.
Glavni frontovi i ključne bitke
Proučavaće se najvažniji frontovi i bitke koje su obeležile Prvi svetski rat.
Rečenični članovi
Učiće se o glavnim i sporednim rečeničnim članovima (subjekat, predikat, objekat, priloške odredbe, atribut, apozicija) i njihovoj funkciji.
Glagoli
Obradićemo glagolska vremena (prezent, futur I, perfekat) i glagolske načine, kao i glagolske oblike (infinitiv, glagolski pridevi i prilozi) i glagolski vid (svršeni i nesvršeni).
Ugljovodonici
Učićete o najjednostavnijim organskim jedinjenjima – ugljovodonicima, uključujući alkane, alkene i alkine, njihove opšte formule i osnovnu nomenklaturu.
Glasovi i glasovne promene
Ponovićemo šta su glasovi i kako se dele, a zatim ćemo učiti o važnim promenama koje se dešavaju kada se glasovi nađu jedan pored drugog u rečima (npr. jednačenje suglasnika po zvučnosti i mestu tvorbe).
Stilske figure
Ponavljaće se i produbljivati znanje o stilskim figurama kao što su epitet, poređenje, metafora, personifikacija, hiperbola, onomatopeja, aliteracija i asonanca, razumevajući njihovu ulogu u tekstu.
Fonetika
Za 8. Razred
Četvorougao
Upoznavanje sa vrstama četvorouglova (paralelogram, pravougaonik, kvadrat, romb, trapez) i njihovim osnovnim svojstvima.
Findest du nicht, was du suchst? Entdecke andere Fächer.
Schüler lieben uns — und du auch.
Die App ist sehr einfach zu bedienen und gut gestaltet. Ich habe bisher alles gefunden, wonach ich gesucht habe, und konnte viel aus den Präsentationen lernen! Ich werde die App definitiv für ein Schulprojekt nutzen! Und natürlich hilft sie auch sehr als Inspiration.
Diese App ist wirklich super. Es gibt so viele Lernzettel und Hilfen [...]. Mein Problemfach ist zum Beispiel Französisch und die App hat so viele Möglichkeiten zur Hilfe. Dank dieser App habe ich mich in Französisch verbessert. Ich würde sie jedem empfehlen.
Wow, ich bin wirklich begeistert. Ich habe die App einfach mal ausprobiert, weil ich sie schon oft beworben gesehen habe und war absolut beeindruckt. Diese App ist DIE HILFE, die man für die Schule braucht und vor allem bietet sie so viele Dinge wie Übungen und Lernzettel, die mir persönlich SEHR geholfen haben.