Professional Documents
Culture Documents
32 in
32 in
7 Indeksi
Obično na kraju knjiga možete naći indeks. U tih nekoliko stranica abecedno su složeni pojmovi koji se spominju u
toj knjizi i na kojoj stranici se nalazi svaki od tih pojmova. Na ovaj način vi možete vrlo jednostavno pronaći pojam
u nekoj knjizi bez listanja kompletne knjige. Slična ideja je i kod indeksa u bazama podaka.
Indeksi su posebni fajlovi koje DBMS kreira ili automatski ili na zahtjev programera. Oni omogućavaju da se brže
pronalazi red koji zadovoljava traženi uslov. Indeks možemo predstaviti kao tabelu sa dvije kolone:
U prvoj koloni ključ smještaju se vrijednosti ključa (ili ključeva) za koji je napravljen indeks. Bitno je naglasiti da je:
Vrijednosti u koloni ključ (ili kolonama ključeva) uvijek su sortirane po rastućem ili opadajućem nizu!
U drugoj koloni se nalazi pointer koji pokazuje gdje se taj podatak nalazi na disku tačnije broj bloka diska.
1. Radnik_ID (PK)
2. Prezime
3. Ime
4. Ime_oca
5. JMBG
6. Datum_zaposlenja
7. Odjel_ID (SK)
Dalje pretpostavimo da svaki red zauzima 100 B i da imamo 1000 radnika. Da bi našli određeni podatak (npr. radnika
po imenu i prezimenu) moramo da pretražimo (bez upotrebe indeksa) i do 100 000 B ili cca 100 KB podataka. Ako
koristimo indeks, pošto je on uvijek složen po traženom ključu, dovoljno je da pročitamo do ključa koji zadovoljava
traženi uslov.
Jasno je da kolona nad kojom se kreira jedinstveni indeks ne može biti NULL kolona.
3
Disk pointer u ovom slučaju je pointer na blok tvrdog diska na kojem se nalazi traženi red. Blok obično sadrži više
sektora (2, 4, 8 čak 16), a sektor je najmanji “komad” memorije koji se može adresirati i sadrži 512B.
BAZE PODATAKA