Kodulehed
[378] - Andmebaasid I (ITI0206) (kevad 2020)
Esiletöstetud Kiirvalik
Lisainfo Kõige olulisemate tegevuste kiirvalik. Failide saatmiseks valige Vastamine alt sobiv ülesanne.
Avaleht
Nagu Moodles
Lindistused
   Loengud
   Praktikumid

Valik materjalidest
   Nädala materjalid
   Minu lemmikud

Vastuste vaatamine
Hinneteleht
Seisuga: 09.06.2020 17:18
Üldist
Materjalid
LisainfoMaterjalide kataloogid.
Hüüumärk (!) tähistab hetkel erilist tähelepanu vajavat kataloogi.
Värvilised mummud tähistavad hinnangulist kataloogide lugemise vajadust. Roheline - suurim, kollane - keskmine, punane või mummuta - väikseim
Isiklik
Lisainfo Info ainult Sulle - teised kasutajad seda ei näe
Abi
Lisainfo Võimalus küsida õppejõult abi (nagu foorum, kus saab küsida küsimusi ja kommenteerida vastuseid)
Mitmesugust
Üldist / Aine tutvustus

Eesmärk: Õppeaine eesmärgiks on anda teadmisi erinevate andmemudelite (sh relatsiooniline, SQL, hierarhiline ja võrkmudel) põhimõtetest ning teadmisi ja oskuseid andmebaasikeelest SQL ning tehingutöötluse SQL-andmebaaside projekteerimisest.

Nii loengute kui praktikumide läbiviija on Erki Eessaar (Erki.Eessaar@taltech.ee).

Ainekaart (ainekava) ÕISis

Tunniplaan ÕISis

Loeng teisipäeviti kell 12:00 ja praktikum kolmapäeviti kell 16:00 on inglise keeles ja eestikeelsetel õppekavadel õppijad seal käia ei saa.

Tegevuskava nädalate kaupa

Hüppa aine kirjelduse juurde

Olulised kuupäevad:

TähtaegKirjeldus
03.02.2020 Kevadsemestri õpingukava esitamise lõpptähtaeg vastavalt akadeemilisele kalendrile
07.02.2020 Iseseisva töö teema registreerimine. Täpsem info
07.02.2020 Enne teise nädala praktikumi algust võiks olla kasutatav tarkvara (MS Access, CASE vahend) oma sülearvutisse installeeritud. Juhendid on SIIN
07.02.2020 Enne teise nädala praktikumi vaadata üle slaidid 166-196 failist SQL-andmebaaside ja nende projekteerimise põhimõisteid. Ei tee paha, kui jõuaksite ka vaadata slaide 1-86. 
16.02.2020 Lugeda mõttega läbi muster "Põhiolemite hetkeseisundi registreerimise vajadus"
23.02.2020 Lugeda mõttega läbi muster "Põhiolemite hetkeseisundi registreerimine SQL-andmebaasis"
25.02.2020-28.02.2020 Esimene vabatahtlik eksami lisapunktide test. Osavõtu soovi korral on registreerimine kohustuslik ja toimub SIIN
11.02.2020-28.02.2020 Iseseisva töö tegemine praktikumides vastavalt juhendile
28.01.2020-28.02.2020 Esimeseks vabatahtlikuks eksami vahetestiks harjutamine SIIN keskkonnas.  
01.03.2020 Lugeda mõttega läbi muster "Põhiolemite seisundimuudatuste võimaldamine graafilises kasutajaliideses"
06.03.2020 Kuuenda õppenädala praktikumiks võiks üle vaadata slaidikomplekti lihtsamate SELECT lausete kohta. Lausete proovimiseks saab kasutada seda andmebaasi
13.03.2020 Seitsmenda õppenädala praktikumiks võiks üle vaadata slaidikomplekti keerukamate SELECT lausete kohta. Lausete proovimiseks saab kasutada seda andmebaasi
02.03.2020-20.03.2020 Teiseks vabatahtlikuks eksami vahetestiks harjutamine SIIN keskkonnas.  
20.03.2020 Kaheksanda õppenädala praktikumiks võiks üle vaadata slaidikomplekti alampäringute kohta SELECT lausetes. Lausete proovimiseks saab kasutada seda andmebaasi
17.03.2020-20.03.2020 Teine vabatahtlik eksami lisapunktide test. Toimub tunniplaanijärgsetel aegadel, nagu ette nähtud - ainult et üle Interneti. 
22.03.2020 Kuupäev, peale midagi ei saa projekti tegija liituda olemasoleva rühmaga (kaks üliõpilast), et nende projekti edasi teha. Endiselt on lubatud projektist eraldumine ja projekti üksinda tegemine, projekti liikme projektist väljaarvamine teiste liikmete poolt ning samuti kahe või kolme üksinda projekti tegija üheks tegijate rühmaks liitumine. 
27.03.2020 Üheksanda õppenädala praktikumiks võiks üle vaadata slaidikomplekti ebaotstarbekate SQL lausete kohta. Lausete proovimiseks saab kasutada seda andmebaasi
31.03.2020 Kell 14:00 (loengu ajal) toimub MS Teams keskkonnas konsultatsioon, kus lahendan läbi portsu üheksanda õppenädala ülesandeid ja vastan küsimustele (vaadake neid ülesandeid SIIT).

Kõik soovijad on oodatud ühinema SELLE lingi kaudu. 
03.04.2020 Kümnenda õppenädala praktikumiks võiks üle vaadata slaidikomplekti andmete muutmise lausete, vaadete ja transaktsioonide kohta. Lausete proovimiseks saab kasutada seda andmebaasi
07.04.2020 Kell 14:00 (loengu ajal) toimub MS Teams keskkonnas konsultatsioon, kus lahendan läbi portsu kümnenda õppenädala ülesandeid ja vastan küsimustele (vaadake neid ülesandeid SIIT). Samuti lahendan läbi SQL kontrolltöö näite ülesandeid (andmebaasi saab SIIT) (seal on erinevat liiki lauseid nõudvaid ülesandeid).

Kõik soovijad on oodatud ühinema SELLE lingi kaudu. 
03.04.2020-09.04.2020 "Mudaste kaartide" anonüümne tagasiside küsitlus. Tagasisidele andmiseks vajutage palun SIIA lingile. 
09.04.2020 Üheteistkümnenda õppenädala praktikumiks võiks üle vaadata slaidikomplekti andmekirjelduskeele lausete kohta
11.04.2020 Pannakse paika lävend, mille ületamisel saab SQL kontrolltöö automaatselt hindeks 5. 
14.04.2020 Kell 14:00 (loengu ajal) toimub MS Teams keskkonnas konsultatsioon, kus lahendan läbi portsu üheteistkümnenda õppenädala ülesandeid ja vastan küsimustele (vaadake neid ülesandeid SIIT). Samuti lahendan läbi veel ühe SQL kontrolltöö näite ülesanded (andmebaasi saab SIIT) (seal on erinevat liiki lauseid nõudvaid ülesandeid).

Kõik soovijad on oodatud ühinema SELLE lingi kaudu. 
17.04.2020 Kaheteistkümnenda õppenädala praktikumiks võiks üle vaadata slaidikomplekti tüüpiliste vigade kohta SQL lausetes ning soovituste kohta kontrolltööks. Lausete proovimiseks saab kasutada seda andmebaasi
03.03.2020-17.04.2020 SQLi harjutamine praktikumides.  
20.04.2020 Tähtaeg andmaks teada oma mitteosalemisest 13nda nädala kontrolltööl. See annab võimaluse kasutada abimaterjali (kahe A4 lehekülje mahus) 16nda nädala järeltööl. Selleks teatamiseks tuleb ennast registreerida Mauruses selleks otstarbeks loodud teadmiste kontrollile
27.01.2020-24.04.2020 Periood, mille jooksul projekti eest arvestuse saamine tähendab lõpphinde arvutamise valemis kordajat 1.3. Projekti näitamiseks tuleb tulla minu vastuvõtuajale (enne 12ndat õppenädalat) või registreerida Mauruses selleks välja pandud ajale (12.-13. õppenädal). e-õppe perioodil toimub kogu projekti ettenäitamine/konsulteerimine kasutades MS Teams'i.

Kordaja 1.3 on neile väga kiiretele üliõpilastele, kes saavad sisuliselt projekti veatult valmis enneaegselt - projektide vaatamise periood, kui kõik praktikumid ja lisaajad on sellele ülesandele pühendatud, algab 14. õppenädalal (siis on kordaja 1.2) ja kestab kuni 9. juunini (siis on kordaja 0.9). Ma ei oska prognoosida varakult näidata soovijate hulka, kuid vabade vastuvõtuaegade pärast on vaja konkureerida teiste projektidega. Seega kes ees, see võitja.
 
23.04.2020-24.04.2020 SQL kontrolltöö. Juhend ja kirjeldus kuidas see toimub on SIIN
27.04.2020-08.05.2020 Periood, mille jooksul projekti eest arvestuse saamine tähendab lõpphinde arvutamise valemis kordajat 1.2
28.04.2020-14.05.2020 Periood, mille jooksul kõik praktikumid on pühendatud iseseisvate tööde ülevaatamisele. 
11.05.2020-15.05.2020 Periood, mille jooksul projekti eest arvestuse saamine tähendab lõpphinde arvutamise valemis kordajat 1.1
15.05.2020 SQL kontrolltöö esimene järeltöö. 
27.05.2020 SQL kontrolltöö teine järeltöö. 
18.05.2020-29.05.2020 Periood, mille jooksul projekti eest arvestuse saamine tähendab lõpphinde arvutamise valemis kordajat 1.0
28.01.2020-08.06.2020 SQLi enesekontroll SIIN keskkonnas. See test on mõeldud SQLi iseseisvaks harjutamiseks. Sellist testi hinde peale ei tehta. SQLi hinne tekib SQL kontrolltöö (ülesannete lahendamine) ja praktikumides lisapunktide ülesannete lahendamise tulemusena.

Kõik selle testi küsimused on ka küsimuste hulgas, millest valitakse hindelise lõpptesti küsimused. Kuigi osad küsimused on teooria kohta, on paljud ka praktilise kallakuga - konkreetsete SQL ülesannete ja nende lahenduste kohta. Küsimustele hästi vastamiseks tasub vaadata teema 3 ja teema 4 materjale.

 
08.06.2020 SQL kontrolltöö kolmas järeltöö. 
09.06.2020 Kõige viimane päev, kui 2019/2020 õppeaasta kevadsemestril saab näidata iseseisvat tööd e projekti. 
27.04.2020-09.06.2020 Iseseisvate tööde ülevaatamise periood. Tööd võib esitada ja ette näidata ka varem - õppejõu vastuvõtuaegadel. Töö arvestuse saamise aeg mõjutab lõpphinnet - mida varem, seda parem hindele. Juhend ja kirjeldus kuidas see toimub on SIIN
01.06.2020-09.06.2020 Periood, mille jooksul projekti eest arvestuse saamine tähendab lõpphinde arvutamise valemis kordajat 0.9
10.06.2020 Viimane eksam käesoleval semestril. 
23.03.2020-10.06.2020 Eksamiks harjutamine SIIN keskkonnas.  

Aine kirjeldus:

Andmebaasid I Andmebaasid I (ITI0206)

Eesmärk: Anda teadmisi erinevate andmemudelite (sh relatsiooniline, SQL, hierarhiline ja võrkmudel) põhimõtetest ning teadmisi ja oskuseid andmebaasikeelest SQL ning tehingutöötluse SQL-andmebaaside projekteerimisest.

Õpiväljundid: Aine läbinud tudeng:

  1. teab erinevaid andmemudeleid, nende alusel andmete organiseerimise erinevusi ning ülesandeid, mille lahendamiseks need sobivad ja ei sobi;
  2. teab andmebaasikeele SQL kasutusvõimalusi ja puudusi;
  3. teab tehingutöötluseks mõeldud SQL-andmebaaside kontseptuaalse, loogilise ja füüsilise projekteerimise ühte võimalikku metoodikat;
  4. teab algtasemel andmebaasisüsteemide ülesehtitust ja funktsionaalsust;
  5. oskab tükeldada andmekeskseid tehingutöötlusele orienteeritud infosüsteeme allsüsteemideks;
  6. oskab projekteerida tehingutöötlusele orienteeritud SQL-andmebaasi ning koostada süsteemi prototüüpi, kasutades selleks UML keelt, CASE vahendit ja vabalt valitud SQL-andmebaasisüsteemi/rakenduse loomise vahendit;
  7. oskab kasutada SQL andmebaasikeelt päringute ja andmemuudatuste läbiviimiseks andmebaasis ning andmebaasi struktuuri (tabelite) ja käitumise (tabelitega seotud deklaratiivsete kitsenduste) loomiseks.

Hindamiskriteeriumid:

  • Õpiväljundite 2, 7 kontrollimine - Kontrolltöö; eksamieeldus.
  • Õpiväljundite 3, 5, 6 kontrollimine - Iseseisev töö - andmebaasi projekteerimine ja prototüüpimine; eksamieeldus.
  • Kõikide õpiväljundite kontrollimine - Teoreetiliste ja praktiliste küsimustega kirjalik (veebipõhine) test e eksam.

Lävendi ületamiseks on vajalik saada iseseisva töö eest arvestus ning nii SQL kontrolltöö kui ka eksami eest vähemalt hinne 1.

lõpphinne = Ümarda ja kärbi((a*0.6 + b*0.4)*c)

Ümardamise näide: 4.4 => 4; 4.5 => 5
Kärpimine tähendab, et kui valemi järgi tuleb hinne üle viie, siis taandatakse see hindeks viis.

a - SQL kontrolltöö hinne

  • 0-50 punkti hinne 0
  • 51-60 punkti hinne 1
  • 61-70 punkti hinne 2
  • 71-80 punkti hinne 3
  • 81-90 punkti hinne 4
  • 91-... punkti hinne 5

Märkused:

  • Praktikumides 2, 6-12 toimub SQL ülesannete lahendamine, mis annab lisapunkte SQL kontrolltööle. Kõik punktide arvuga teatud lävendi ületanud üliõpilased saavad kontrolltöö hindeks automaatselt 5, st ei pea kontrolltööd tegema. Lävend sõltub kursuse tasemest ja määratakse kindlaks üheteistkümnenda õppenädala lõpuks.
  • Kontrolltöö ülesannete lahendamise eest saadav võimalik maksimaalne punktisumma on 100.
  • Semestri praktikumides kogutud SQL lisapunktid lähevad kontrolltöö hinde arvutamisel arvesse põhitööl (13ndal õppenädalal) ja esimesel järeltööl (16ndal õppenädalal).
  • SQLi kontrolltöö hinne kehtib ainult saamise semestril. Seega uuesti deklareerides tuleb SQLi kontrolltöö uuesti teha või saada tulemus lisapunktidega.
  • Lisapunktid lähevad arvesse ainult saamise semestril.

b - eksami hinne

  • 0-50 punkti hinne 0
  • 51-60 punkti hinne 1
  • 61-70 punkti hinne 2
  • 71-80 punkti hinne 3
  • 81-90 punkti hinne 4
  • 91-... punkti hinne 5

Märkused:

  • Eksami küsimustele vastamise eest saadav võimalik maksimaalne punktisumma on 100. Eksami testis on 25 küsimust, iga õige vastus annab neli punkti. Eksamile on võimalik lisapunktide testidega kaasa võtta kuni 20 lisapunkti.
    • Viiendal õppenädalal praktikumis toimuv lisapunktide test võimaldab eksamile juurde saada kuni 10 punkti. Testis on kümme küsimust, iga õige vastus annab ühe punkti.
    • Kaheksandal õppenädalal praktikumis toimuv lisapunktide test võimaldab eksamile juurde saada kuni 10 punkti. Testis on kümme küsimust, iga õige vastus annab ühe punkti.
  • SQL lisapunktid, mis ületavad üheteistkümnenda õppenädala lõpuks määratavat SQL lisapunktide lävendit (lävendi ületamine annab SQL kontrolltöö hindeks automaatselt 5), lähevad eksami lisapunktideks.
  • Eksami hinne kehtib ainult saamise semestril. Seega uuesti deklareerides tuleb eksam uuesti teha.
  • Lisapunktid lähevad arvesse ainult saamise semestril.

c - iseseisva töö projekti kordaja

Kui iseseisva töö projekt arvestatakse:

  • 1.-13. õppenädalal, siis 1.3
  • 14.-15. õppenädalal, siis 1.2
  • 16. õppenädalal, siis 1.1
  • 17.-18. õppenädalal (eksamisessioon), siis 1.0
  • 19.-20. õppenädalal (eksamisessioon), siis 0.9

Märkused:

  • Varasematel semestritel saadud projekti arvestused kehtivad. Hindamisel kasutatav kordaja määratakse kindlaks vastavalt jooksval semestril kehtivatele reeglitele.

Lävend

  • Kui a väätus puudub või a=0, siis eksamit tegema ei pääse ja lõpphinnet ei saa.
  • Kui c väätus puudub (projekt arvestamata), siis eksamit tegema ei pääse ja lõpphinnet ei saa.
  • Kui b=0, siis on lõpphinne 0.

Teemad: Andmebaas. Andmebaasisüsteem. Andmemudelid, sh NoSQL süsteemides kasutatavad andmemudelid. Relatsiooniline andmemudel. Relatsioonialgebra. SQL andmebaasikeel ja selle abil loodavad andmebaasiobjektid. SQLi puudused. Tehingutöötluseks mõeldud SQL-andmebaasi projekteerimise võimalik metoodika, sh selle käigus loodavad UML mudelid. Strateegiline analüüs. Detailanalüüs. Olemi-suhte diagrammid ja nende loomine UMLi abil. Andmete modelleerimise mustrid. Normaliseerimine. Denormaliseerimine. Transaktsioonilise SQL-andmebaasi loogiline ja füüsiline disain. CASE vahendi kasutamine andmebaasi projekteerimiseks.

Siit võite vaadata teemade mõistekaarte

Märkus: Selle õppeaine edukaks läbimiseks ei ole mitte mingit kohustust ega vajadust ühtegi järgnevatest allikatest lehitseda ega lugeda. Õppeaine edukaks sooritamiseks on piisav, kui õppida sellel kodulehel olevate materjalide alusel.

Siiski pakun välja kursuse põhiteemade kaupa ühe võimaliku kombinatsiooni raamatutest, mida sügavama huvi korral lugeda. Mõned nendest raamatutest on e-raamatud, mida saab lugeda Tallinna Tehnikaülikooli raamatukogu kaudu. Siin on informatsioon, kuidas pääseb nendele raamatutele ligi väljastpoolt Tallinna Tehnikaülikooli võrku.

  • SQL: Head First SQL (e-raamat O'Reilly digitaalse platvormi kaudu. Kuidas kasutada O'Reilly digitaalset platvormi?) või SQL Queries for Mere Mortals. (e-raamat O'Reilly digitaalse platvormi kaudu. Kuidas kasutada O'Reilly digitaalset platvormi?)

    Siit saab Downloads saki alt "SQL Queries for Mere Mortals" raamatu jaoks näidistabelitega andmebaasid, mis sisaldavad ka Queridena ära salvestatud ülesannete lahendusi.

    Suur tänu üliõpilasele, kes "SQL Queries for Mere Mortals" raamatut soovitas. Ta kirjutas: "Tekst on konkreetne, seletused tõhusad. Õpikut pole koormatud lisainfot sisaldavate artiklitega nagu mõnedel ingliskeelsetel õpikutel standardiks (nõnda on lihtsam tekstile keskenduda). Iga SQL süntaksiga tegeleva peatüki lõppu paigutatud ülesanded aitavad materjali kinnistada. Parima tulemuse jaoks võiks tudeng ka Sample Statements sektsioonides püstitatud ülesandeid lahendada üritada (enne ülesannete juurde asumist). Pärast Access'is SQL Server Compatible Syntax'i kasutuselevõttu võivad mõned näidisandmebaasides valmis kirjutatud päringud vajada ümber kirjutamist, kuid see vast pole mitte kellegi jaoks üle jõu."

    Minult on küsitud Head First sarja ja Head First SQL raamatu kohta. Oskan öelda, et see raamat on kirjutatud omapärase stiilis ning huumorit kasutades. Leian, et seda saab SQLiga esmatutvuse tegemiseks väga edukalt kasutada. Näiteks lk 44 on hea kirjeldus NULLi olemusest.

    Samas on raamatus ka ebatäpseid väiteid. Näiteks väide "A database is a container that holds tables and other SQL structures related to those tables" jätab lugejale vale mulje, et tabelid on ainsad võimalikud andmebaaside ehitusplokid. Tegelikult see nii ei ole ja on palju erinevaid andmemudeleid, mis pakuvad kasutamiseks erinevaid andmebaaside ehitusplokke. Õigem oleks öelda "A SQL database is a container that holds tables and other SQL structures related to those tables".

  • Relatsiooniline mudel: Database in Depth (e-raamat O'Reilly digitaalse platvormi kaudu. Kuidas kasutada O'Reilly digitaalset platvormi?) või An Introduction to Relational Database Theory
  • Tehingutöötluse SQL-andmebaaside kavandamine: Andmebaaside projekteerimine ja SQL Antipatterns. (e-raamat O'Reilly digitaalse platvormi kaudu. Kuidas kasutada O'Reilly digitaalset platvormi?) (Kellele meeldib raamatut peos hoida, see leiab antimustrite raamatu ka Tallinna Tehnikaülikooli raamatukogust. Samuti on olemas selle raamatu alusel koostatud slaidikomplekt.)

Käesolevas kursuses kasutame andmebaaside projekteerimiseks UML modelleerimiskeelt. Sellega esmatutvuse tegemiseks või tutvuse värskendamiseks lugege raamatut UMLi kontsentraat. 3. redaktsioon. Objektmodelleerimise standardkeele UML2.0 lühijuhend.

Eraldi tõstan esile ja soovitan raamatut Building the agile database : how to build a successful application using agile without sacrificing data management.

Kui seda andmebaaside kursuste ajal või järel loete, siis peaksid paljud seal kirjeldatavad põhimõtted Teile andmebaaside ainetest tuttavad olema. Loodan, et selle raamatu lugemine annab Teile kinnitust ja julgustust, et nende jälgimine on mõistlik, võimalik ja kasulik ka tänapäeva moodsa agiilse (paindliku) süsteemiarenduse käigus.

Raamatus palju käsitlemist leidev loogiline andmemudel on sisuliselt sama kui andmebaaside ainetes käsitletud detailne kontseptuaalne andmemudel.

Rõhutan, et see on ainult üks, kuid sugugi mitte ainus võimalik kombinatsioon. Häid raamatuid on hulgaliselt ja paljud nendest on ka Teile kättesaadavad. Lisamaterjalide lehel (kasutajanimi: SIS2 ja parool: SIS2) leiab SIIT viiteid suurele hulgale raamatutele. Rõhutan, et nende lugemine pole kohustuslik.

Õppejõud: dotsent Erki Eessaar
meiliaadress: Erki.Eessaar(ät)taltech.ee