Napredni SQL upiti su ono što te odvaja od početnika... Mostra di più
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!

Pensavamo che non l'avreste mai chiesto....
Che cos'è l'assistente AI di Knowunity?
Il nostro assistente AI è costruito specificamente per le esigenze degli studenti. Sulla base dei milioni di contenuti presenti sulla piattaforma, possiamo fornire agli studenti risposte davvero significative e pertinenti. Ma non si tratta solo di risposte, l'assistente è in grado di guidare gli studenti attraverso le loro sfide quotidiane di studio, con piani di studio personalizzati, quiz o contenuti nella chat e una personalizzazione al 100% basata sulle competenze e sugli sviluppi degli studenti.
Dove posso scaricare l'applicazione Knowunity?
È possibile scaricare l'applicazione dal Google Play Store e dall'Apple App Store.
Knowunity è davvero gratuita?
Sì, hai accesso completamente gratuito a tutti i contenuti nell'app e puoi chattare o seguire i Creatori in qualsiasi momento. Sbloccherai nuove funzioni crescendo il tuo numero di follower. Inoltre, offriamo Knowunity Premium, che consente di studiare senza alcun limite!!
Contenuti più popolari di 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.
Contenuti più popolari
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.
Non c'è niente di adatto? Esplorare altre aree tematiche.
Recensioni dei nostri utenti. Ci adorano - e anche tu, vedrai .
L'applicazione è molto facile da usare e ben progettata. Finora ho trovato tutto quello che cercavo e ho potuto imparare molto dalle presentazioni! Utilizzerò sicuramente l'app per i compiti in classe! È molto utile anche come fonte di ispirazione.
Questa applicazione è davvero grande! Ci sono tantissimi appunti e aiuti con lo studio [...]. La mia materia problematica, per esempio, è il francese e l'app ha così tante opzioni per aiutarmi. Grazie a questa app ho migliorato il mio francese. La consiglio a tutti.
Wow, sono davvero stupita. Ho appena provato l'app perché l'ho vista pubblicizzata molte volte e sono rimasta assolutamente sbalordita. Questa app è L'AIUTO che cercate per la scuola e soprattutto offre tantissime cose, come allenamenti e schede, che a me personalmente sono state MOLTO utili.
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... Mostra di più

Iscriviti per mostrare il contenuto. È gratis!
- Accesso a tutti i documenti
- Migliora i tuoi voti
- Unisciti a milioni di studenti
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.

Iscriviti per mostrare il contenuto. È gratis!
- Accesso a tutti i documenti
- Migliora i tuoi voti
- Unisciti a milioni di studenti
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.

Iscriviti per mostrare il contenuto. È gratis!
- Accesso a tutti i documenti
- Migliora i tuoi voti
- Unisciti a milioni di studenti
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!

Iscriviti per mostrare il contenuto. È gratis!
- Accesso a tutti i documenti
- Migliora i tuoi voti
- Unisciti a milioni di studenti
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!

Iscriviti per mostrare il contenuto. È gratis!
- Accesso a tutti i documenti
- Migliora i tuoi voti
- Unisciti a milioni di studenti
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.

Iscriviti per mostrare il contenuto. È gratis!
- Accesso a tutti i documenti
- Migliora i tuoi voti
- Unisciti a milioni di studenti
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!

Iscriviti per mostrare il contenuto. È gratis!
- Accesso a tutti i documenti
- Migliora i tuoi voti
- Unisciti a milioni di studenti
Pensavamo che non l'avreste mai chiesto....
Che cos'è l'assistente AI di Knowunity?
Il nostro assistente AI è costruito specificamente per le esigenze degli studenti. Sulla base dei milioni di contenuti presenti sulla piattaforma, possiamo fornire agli studenti risposte davvero significative e pertinenti. Ma non si tratta solo di risposte, l'assistente è in grado di guidare gli studenti attraverso le loro sfide quotidiane di studio, con piani di studio personalizzati, quiz o contenuti nella chat e una personalizzazione al 100% basata sulle competenze e sugli sviluppi degli studenti.
Dove posso scaricare l'applicazione Knowunity?
È possibile scaricare l'applicazione dal Google Play Store e dall'Apple App Store.
Knowunity è davvero gratuita?
Sì, hai accesso completamente gratuito a tutti i contenuti nell'app e puoi chattare o seguire i Creatori in qualsiasi momento. Sbloccherai nuove funzioni crescendo il tuo numero di follower. Inoltre, offriamo Knowunity Premium, che consente di studiare senza alcun limite!!
Contenuti più popolari di 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.
Contenuti più popolari
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.
Non c'è niente di adatto? Esplorare altre aree tematiche.
Recensioni dei nostri utenti. Ci adorano - e anche tu, vedrai .
L'applicazione è molto facile da usare e ben progettata. Finora ho trovato tutto quello che cercavo e ho potuto imparare molto dalle presentazioni! Utilizzerò sicuramente l'app per i compiti in classe! È molto utile anche come fonte di ispirazione.
Questa applicazione è davvero grande! Ci sono tantissimi appunti e aiuti con lo studio [...]. La mia materia problematica, per esempio, è il francese e l'app ha così tante opzioni per aiutarmi. Grazie a questa app ho migliorato il mio francese. La consiglio a tutti.
Wow, sono davvero stupita. Ho appena provato l'app perché l'ho vista pubblicizzata molte volte e sono rimasta assolutamente sbalordita. Questa app è L'AIUTO che cercate per la scuola e soprattutto offre tantissime cose, come allenamenti e schede, che a me personalmente sono state MOLTO utili.