You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 3 Next »

Mikä on tietokanta?

  • Tietokanta on kokoelma yhteenliittyvää tietoa (data)
  • Tietokanta on loogisesti yhtenäinen kokoelma tietoa jolla on jokin merkitys.
  • Tietokanta on suunniteltu, rakennettu ja täytetty tiedolla jotain tiettyä tarkoitusta varten. Sillä on jokin tarkoitettu käyttäjäryhmä ja joitain ennaltalaadittuja ohjelmia joita käyttäjät käyttävät.

Mitä hyötyä on tietokannoista?

Nimeä ei voi syöttää jollei syötä myös osoitetta. Osoitetta ei voi poistaa jos se liittyy johonkin nimeen. Tietokannat, Viite-eheys (Referential Integrity) Heikot kohteet (Weak entities). Ohjelmoinnillinen pääsy tietoihin. 

tiedonsaantiinTietokannatTietokantaskeemat (Database schemas)Standardoidut liittymärajapinnat (ODBC / JDBC)Upotetut kyselyt (Embedded Queries). Monta päivitystä, jotka tehdään joko kaikki tai ei yhtään.

Esimerkit

Kaksi taloutta muuttaa yhteen eli täytyy muuttaa usean henkilön asumistietoja. Mitä jos tietokone kaatuu kesken muutosten?

Ratkaisu

Esitetään, että kaikki päivitykset tehtäisiin yhtäaikaaMahdollistetaan vahvistuksien (commit) ja peruutuksien (rollback) avulla

Tietokannat

Tapahtumien hallinta (Transaction management)

Jakamattomuus (Atomicity)

Tietokone kaatuu

Ovatko tiedot vielä tallessa? Ovatko tiedot muuttumattomat?

Ratkaisu

Varmistetaan, että kaikki vanha data on saatavilla viimeiseen hyväksyntään (commit) saakka.

Tietokannat

Pysyvyys (Durability)

Elvytys (Recovery) Useampi tietokone saman tiedon käsittelijänä

Esimerkit:

Kaksi käyttäjää päivittää tietokantaa yhtäaikaaRatkaisuTapahtumat ovat atomisia eli eivät jakaudu osiinTapahtumat tapahtuvat peräkkäin jossakin järjestyksessäTietokannatSamanaikaisuuden hallinta (Concurrency Control)Transaction isolationTransaction serializability

Yleisiä vaatimuksia tietokannalta

  • Kukin tieto tallennetaan tietokannassa vain yhteen paikkaan eli ei esiinny turhaa toistuvuutta (redundanssia)
  • Tietoja pystytään hakemaan joustavasti erilaisin perustein, myös sellaisin, joita ei tietokantaa suunnitellessa ole pystytty ennakoimaan.
  • Tietokannan rakenteellinen muuttaminen on joustavaa
  • Hyväksikäyttö ja sovellusohjelmat ovat riippumattomia tietojen fyysisestä talletusrakenteesta: tietoriippumattomuus

http://www.bell-labs.com/topic/books/db-book/b.pdf

Relaatiotietokannat

  • E.F. Codd esitteli relaatiomallin jo 1970
  • yksinkertaisin, joustavin ja toteuttaa parhaiten tietokannalle asetettavat vaatimukset
  • Vaatii eniten koneresursseja
  • Relaatiotietokannassa tiedot esitetään tauluina (table) yhtä riviä kutsutaan tietueeksi (record)
  • taulun jokaisella rivillä yhtä monta tietoa
  • jokaisella rivillä yksikäsitteinen perusavain
  • kutakin riviä vastaa jokin reaalimaailman kohde
  • kuhunkin kohteeseen liitetään vain siihen välittömästi liittyvät ominaisuudet
  • tauluja kutsutaan myös relaatioiksi
  • Kukin yksittäinen tieto kannassa voidaan hakea ainakin ilmoittamalla taulun nimi, perusavaimen sarakenimi ja avaimen arvo sekä haettavan tiedon sarakenimi. Ainakin tämä hakutapa olemassa, lisäksi lukemattomia muita.

Tietokannan hallintajärjestelmät

Tietokannan hallintaan tarkoitettu ohjelmisto esim. Oracle, DB2, Ingres ja SQL Server. Tietyin rajoituksin tietokannan hallintajärjestelmäksi voi kutsua myös Accessia ja Paradoxia.

Hallintajärjestelmän perusvaatimukset

  • Perusoperaatiot (tallennus, haku, päivitys)
  • Tietoriippumattomuus
  • Yhteiskäyttö
  • Ylimäärättömyys
  • Eheys
  • Turvaaminen
  • Tehokkuus ja suorituskyky
  • Yhteensopivuus
  • Skaalautuvuus

Tietokannan hallintajärjestelmien huonoja puolia

  • Monimutkaisuus
  • Koko
  • Hinta
  • Laitteistokustannukset
  • Muutoskustannukset
  • Suorituskyky
  • Vahinkojen suuri vaikutus

Lähteet

  • No labels
You must log in to comment.