Professional Documents
Culture Documents
IEP-7-NoSQL (Novo 2018)
IEP-7-NoSQL (Novo 2018)
dr Miloš CVETANOVIĆ
dr Zaharije RADIVOJEVIĆ
• Relacione baze podataka (SQL):
– Dizajnirane za interkaciju sa korisnikom (user-oriented)
– Potrebe za agregatnim informacijama
– Potreba za implicitnom kontrolom:
konkurentnost, integritet, konzistencija, validacija
Osobine:
Dokument orjentisana baza podataka
Podrška za dinamičke upite
Podrška za različite tipove indeksa
Podrška za replikaciju i visoki nivo dostupnosti
Podrška za horizontalnu skalabilnost
Podrška za atomične modifikacije
Podrška za map/reduce poslove
Podrška za čuvanje velikih dokumenata
Relacioni pristup Ne relacioni pristup
|_media |_media
|_cds |_items
|_id, artist, title, genre, releasedate |_<document>
|_ cd_tracklists
|_cd_id, songtitle, length
{
"Type": "CD", Binarni JSON (JavaScript Object Notation)→ BSON
"Artist": "Nirvana",
"Title": "Nevermind",
{_id: ObjectId(XXXXXXXXXXXX), Hello: “world”}
"Genre": "Grunge",
"Releasedate": "1991.09.24", \x27 \x00 \x00 \x00 \x07 _ i d \x00
"Tracklist": [ XXXXXXXXXXXX
\x02 h e l l o \x00
{ "Track" : "1", \x06 \x00 \x00 \x00 w o r l d \x00
"Title" : "Smells Like Teen Spirit", \x00
"Length" : "5:02"},
{ "Track" : "2",
"Title" : "In Bloom", _id polje – 12B ( automatski ili pozivom ObjectId() )
"Length" : "4:15"} 0 1 2 3 4 5 6 7 8 9 10 11
]
Vreme Mašina Proces Brojač
}
Osnovne komande ( raspakovati arhivu → kreirati C:\data\db → pokrenuti )
> db.media.insert(document)
> db.media.find().limit( 10 )
> db.media.find().skip( 20 )
> db.media.find().sort ( { Title : -1 } ).limit ( 10 ).skip ( 20 )
> db.media.group (
{ → key – funkcija koja obavlja grupisanje
key: {Title : true}, cond – dodatni uslov za svaki dokument
initial: {Total : 0}, finalize – funkcija pre prikaza rezltata
reduce : function (items,prev) { prev.Total += 1}
}
)
[ { "Title" : "Nevermind“, "Total" : 1},
{"Title" : "Definitive Guide to MongoDB, the", "Total" : 2 } ]
> dvd = ( { "Type" : "DVD", "Title" : "Matrix, The", "Released" : 1999,
"Cast" : ["Keanu Reeves","Carry-Anne Moss","Laurence Fishburne","Hugo
Weaving","Gloria Foster","Joe Pantoliano"] } )
> db.media.insert(dvd)
> dvd = ( { "Type" : "DVD", "Title" : "Blade Runner", "Released" : 1982 } )
> db.media.insert(dvd)
> dvd = ( { "Type" : "DVD", "Title" : "Toy Story 3", "Released" : 2010 } )
> db.media.insert(dvd)
→ skip i limit ne rade nad nizovima → npr. $slice: [-5,4] skoči na poslednjih 5, limitira na 4
> db.media.find ( { Tracklist : {$size : 2} } )
→ samo oni dokumenti sa tačnom dužinom niza
> manga = ( { "Type" : "Manga", "Title" : "One Piece", "Volumes" : 612, "Read" : 520 } )
> db.media.insert(manga)
> db.media.update ( { "Title" : "One Piece"}, {$inc: {"Read" : 4} } )
→ skript koji vraća imena članova napisana velikim slovima, sortiranim po alfabetu
db.users.aggregate( [
{ $project : { name:{$toUpper:"$_id"} , _id:0 } },
{ $sort : { name : 1 } }
]
)
→ skript koji za svakog člana vraća mesec učlanjenja i ime, sortiranim po mesecu
db.users.aggregate([
{ $project : { month_joined : { $month : "$joined"},
name : "$_id",
_id : 0
},
{ $sort : { month_joined : 1 } }
]
)
→ skript koji vraća informaciju o tome koliko je novih članova bilo po mesecima
db.users.aggregate([
{ $project : { month_joined : { $month : "$joined" } } } ,
{ $group :
{ _id : {month_joined:"$month_joined"} ,
number : { $sum : 1 }
}
},
{ $sort : { "_id.month_joined" : 1 } }
] {
) _id : "jane",
joined : ISODate("2011-03-02"),
→ skript koji vraća pet najčešće omiljenih sportova likes : ["golf", "racquetball"]
db.users.aggregate([ }
{ $unwind : "$likes" },
{ $group : {
{ _id : "$likes" , _id : "jane",
number : { $sum : 1 } joined : ISODate("2011-03-02"),
} likes : "golf"
}
}, {
{ $sort : { number : -1 } }, _id : "jane",
{ $limit : 5 } joined : ISODate("2011-03-02"),
likes : "racquetball"
] }
)
• Konceptualni i logički modela
• Fizički model (MongoDB)
– Ugrađivanje ili referisanje (embed, reference)
– Čuvanje istorije
– Indeksiranje i distribucija (sharding)
• Ugrađivanje:
– Česti upiti nad dva ili više entiteta (poslovna logika je faktor)
– Redukcija veza sa kardinalnošću učešća (0,1)
– Redukcija odnosa specijalizacije
– Redukcija odnosa zavisnosti
• Redukcija odnosa zavisnosti (identifikaciona ili egzistencijalna)
koja ima gornju granicu kardinalnosti uslovljavanja je 1
• Identifikaciono zavistan slabi entitet (bez obzira na kardinalnost)
• Referisanje:
– Entitet veze N-N ima i druge odnose (npr. agregacija)
– Entitet veze N-N sa velikim brojem povezanih instanci
(npr. u jednoj porudžbini ima po više od 20 stavki proizvoda)
– Entitete koji imaju jako različitu učestalost promene
– Ukoliko je upis (Ins, Upd, Del) važniji od čitanja (Sel)
• Čuvanje istorije (sporo promenljive dimenzije)
(Slowly Changing Dimension – SCD)
– Tip 0: Čuva se samo originalna vrednost, a ne promene
– Tip 1: Čuva se samo promena
– Tip 2: Čuva se kompletna istorija (original, sve promene)
– Tip 3: Čuva se neki deo istorije
(npr. original i poslednja promena, ili poslednje dve promene)