582104 Ohjelmistojen mallintaminen, olioja relaatiomallinnuksen suhteesta



Samankaltaiset tiedostot
Ohjelmistojen mallintamisen ja tietokantojen perusteiden yhteys

2. Käsiteanalyysi ja relaatiomalli

Tietokannat II -kurssin harjoitustyö

Tietokantojen suunnittelu, relaatiokantojen perusteita

Tietokannat II -kurssin harjoitustyö

HELIA 1 (17) Outi Virkki Tiedonhallinta

YHTEYSSUHDE (assosiation)

Mikä yhteyssuhde on?

Tehtävä 1. Tietojen lisääminen, poistaminen, päivittäminen ja tulostaminen

TIEDONHALLINTA - SYKSY Luento 2. Pasi Ranne /8/17 Helsinki Metropolia University of Applied Sciences

Tietokantakurssit / TKTL

Tietokannan hallinta. Kevät 2004 Jan Lindström R&G Chapter 1

3. Käsiteanalyysi ja käsitekaavio

Rajapinta (interface)

Lohdutus - tietokantadokumentti

Kompositio. Mikä komposition on? Kompositio vs. yhteyssuhde Kompositio Javalla Konstruktorit set-ja get-metodit tostring-metodi Pääohjelma

1 Tehtävän kuvaus ja analysointi

Tiedonhallinnan perusteet. H11 Ovien ja kulun valvontajärjestelmän tietokanta

JAVA-PERUSTEET. JAVA-OHJELMOINTI 3op A JAVAN PERUSTEET LYHYT KERTAUS JAVAN OMINAISUUKSISTA JAVAN OMINAISUUKSIA. Java vs. C++?

SQL-perusteet, SELECT-, INSERT-, CREATE-lauseet

Insert lauseella on kaksi muotoa: insert into taulu [(sarakenimet)] values (arvot)

Yleistä. Nyt käsitellään vain taulukko (array), joka on saman tyyppisten muuttujien eli alkioiden (element) kokoelma.

HSMT Tietokannoista. Ville Leppänen. HSMT, c Ville Leppänen, IT, Turun yliopisto, 2008 p.1/32

1. Olio-ohjelmointi 1.1

Ohjelmistojen mallintaminen, mallintaminen ja UML

TIEDONHALLINTA - SYKSY Luento 7. Pasi Ranne /10/17 Helsinki Metropolia University of Applied Sciences

15. Ohjelmoinnin tekniikkaa 15.1

Metodien tekeminen Javalla

D B. Tietokannan hallinta - kurssin tavoite. Kurssilla opitaan periaatteet. Edellytyksenä osallistumiselle on Tietokantojen perusteiden hallinta

UML ja luokkien väliset suhteet

Ohjelmistojen mallintaminen, sekvenssikaaviot

Tietomallit. Näkökulmat tietoon. Näkökulmat tietoon. Mitä malleja olisi tarjolla? Abstraktiotasot tiedon käsittelyssä

HELIA 1 (14) Outi Virkki Tiedonhallinta

Sisältö. 2. Taulukot. Yleistä. Yleistä

Olio-ohjelmointi Javalla

HELIA 1 (12) Outi Virkki Tiedonhallinta

On autoja, henkilöitä, Henkilöllä on nimi Autolla on omistaja, joka on henkilö. Taulu AUTO(rekno, malli) Taulu HENKILO(nimi, )

2. Olio-ohjelmoinista lyhyesti 2.1

Ohjelmistojen mallintaminen Olioiden yhteistyö Harri Laine 1

Taulukot. Jukka Harju, Jukka Juslin

Opintopiiritehtävä 3: Verkkohuutokauppa

Tietokantasuunnittelun pääperiaatteena on tiedon toiston välttäminen. Tiedon toistumiseen liittyy monenlaisia ongelmia.

3. Taulujen määrittely ja muuttaminen

Helsingin yliopisto/tktl DO Tietokantojen perusteet, s 2000 Relaatiomallin peruskäsitteet Harri Laine 1. Relaatiotietokannat DONOTP

Ohjelmointi 2 / 2008 Välikoe / Pöytätestaa seuraava ohjelma.

POLKU LUOKKAKAAVIOISTA TAULUJEN TOTEUTUKSEEN

3. TAULUJEN MÄÄRITTELY JA MUUTTAMINEN

Ohjelmointitaito (ict1td002, 12 op) Kevät Java-ohjelmoinnin alkeita. Tietokoneohjelma. Raine Kauppinen

CSE-A1200 Tietokannat

Visual Case 2. Miika Kasnio (C9767)

Oliosuunnitteluesimerkki: Yrityksen palkanlaskentajärjestelmä

Sisältö. 22. Taulukot. Yleistä. Yleistä

Kirjoita jokaiseen erilliseen vastauspaperiin kurssin nimi, tenttipäivä, oma nimesi (selkeästi), opiskelijanumerosi ja nimikirjoituksesi

HELIA 1 (11) Outi Virkki Tiedonhallinta

ALMU-järjestelmä Suunnitteludokumentti

Java-kielen perusteet

Sisällys. 19. Olio-ohjelmointia Javalla. Yleistä. Olioiden esittely ja alustus

Metodit. Metodien määrittely. Metodin parametrit ja paluuarvo. Metodien suorittaminen eli kutsuminen. Metodien kuormittaminen

Java-kielen perusteet

Tietotekniikan laitos Käki-projekti TIETOKANTASUUNNITELMA. 1. Johdanto

Luokkamalli LUOKKAKAAVIO. Tämän osan sisältö. Luokkamalli. Luokka ja olio. Luokkakaavio (class diagram)

Java ja tietokannan käsittely (JDBC)

Ohjelmistotekniikan menetelmät, UML

Opintojakso TT00AA11 Ohjelmoinnin jatko (Java): 3 op Taulukot & Periytyminen

Harjoitustehtävä 1. Harjoitustehtävä 2. Harjoitustehtävä 2. Harjoitustehtävä 2. Harjoitustehtävä 2. SQL kysely

4. Luokan testaus ja käyttö olion kautta 4.1

CS-A1150 Tietokannat CS-A1150 Tietokannat / 43

Relaatiomalli ja -tietokanta

15. Ohjelmoinnin tekniikkaa 15.1

1. Omat operaatiot 1.1

Listarakenne (ArrayList-luokka)

CS-A1150 Tietokannat CS-A1150 Tietokannat / 44

5. HelloWorld-ohjelma 5.1

TIE Samuel Lahtinen. Lyhyt UML-opas. UML -pikaesittely

HAAGA-HELIA heti09 1 (27) ICT05 Tiedonhallinta ja tietokannat O.Virkki Relaatiomalli

Opettajana Mika Sorsa, HAMK:n ammatillisen opettajakoulutuksen opetusharjoittelija

Tietokannan suunnittelu

HAAGA-HELIA TIKO-05 1 (19) ICT23a Tietokannan suunnittelu ja toteutus O.Virkki

Ohjelmoinnin jatkokurssi, kurssikoe

SQL - STRUCTURED QUERY LANGUAGE

19. Olio-ohjelmointia Javalla 19.1

Jouni Huotari & Ari Hovi. Käsitemallinnuksesta relaatiokantaan KÄSITEMALLI. LOOGINEN MALLI: tietomalli valittu. FYYSINEN MALLI: DBMS valittu

11. Javan toistorakenteet 11.1

Osio2: Taulukot Jukka Juslin

Oliotietokannat. Nääsvillen Oliopäivät Pekka Kähkipuro Kehitysjohtaja, FT

9. Periytyminen Javassa 9.1

HELIA 1 (20) Outi Virkki Tiedonhallinta

Tietokantasovellus: drinkkiarkisto

16. Javan omat luokat 16.1

A) on käytännöllinen ohjelmointitekniikka. = laajennetaan aikaisemmin tehtyjä luokkia (uudelleenkäytettävyys)

Ylläpitodokumentti. Oppimistavoitteiden hallintajärjestelmä harri

Ohjelmointi 1 / 2009 syksy Tentti / 18.12

TIEDONHALLINNAN PERUSTEET - SYKSY 2013

Kirjasto Relaatiotietokannat Kevät Auvinen Annemari Niemi Anu Passoja Jonna Pulli Jari Tersa Tiina

Ohjelmointi 2 / 2010 Välikoe / 26.3

HELIA 1 (19) Outi Virkki Tietokantasuunnittelu

Tietomallit. Näkökulmat tietoon. Näkökulmat tietoon. Näkökulmat tietoon. Abstraktiotasot tiedon käsittelyssä

TIETOKANTOJEN PERUSTEET OSIO 11 MARKKU SUNI

11. Javan valintarakenteet 11.1

12. Javan toistorakenteet 12.1

Transkriptio:

582104 Ohjelmistojen mallintaminen, olioja relaatiomallinnuksen suhteesta 1

Tietojen pysyvyys liiketoiminnan edellytys Tällä kurssilla on keskitytty oliomenetelmiä hyödyntävään ohjelmistojen mallintamiseen Rinnakkainen kurssi Tietokantojen perusteet käsittelee relaatioteoriaa hyöndyntävään tietosisällön mallintamiseen Oliomallinnus on de facto standardi ohjelmistojen toiminnan mallintamiseksi Relaatiomallinnus on de facto standardi pysyväisluonteisen tiedon mallintamiseksi Toimiva liiketoimintajärjestelmä käyttää pysyväisluonteista dataa 2

Sisältö Tietosisällön mallintaminen relaatio- ja oliomaailmassa Olio- ja relaatiomallin yhteensovittaminen (ORM) Hibernate kehyksen pikaesittely Kirjastoesimerkin sovittaminen Hibernatesovellukseksi 3

Tiedon mallintaminen relaatiokannassa Relaatiokannassakin mallinnetaan järjestelmän tietosisältöä useammalla abstraktiotasolla Kohdealuetta mallinnetaan esimerkiksi ER-kaavioilla (entity-relationship) Taulukaavioin (SQL-taulut) Fyysisen tallennuksen kaavioin Järjestelmän suorituskyky tärkeä tekijä, tarkoituksena löytää tehokkaat tallennusformaatit Tietokannan hallintajärjestelmä käsittelee miljoonia tai miljardeja rivejä 4

Käsitetaso, rakennetaso, tallennustaso 5

Oliomallinnuksen käyttäminen relaatiokannan yhteydessä UML-luokkamallilla pystytään monesti saavuttamaan ER-kaaviota vastaava ilmaisuvoima Useimmat oliokielet eivät kuitenkaan tue tehokasta tietojen säilyttämistä ja hakemista, joten monesti tietojen pysyvyyden varmistamiseksi käytetään SQL-kantaa Olio- ja relaatiomallien yhteensovittamiseksi voidaan käyttää olio-relaatiokuvauksia (object-torelational mapping, ORM) 6

Relaation esittäminen taulumuodossa Relaatiot esitetään SQL:ssä taulumuodossa Käsitteiden väliset yhteydet esitetään viite- ja pääavainten välisten arvojen samuudella 7

Olioiden esittäminen UML:ssä 8

Olioiden esittäminen relaatiokannassa Yksinkertaisessa tapauksessa olioiden tallentaminen relaatiokantaan on suoraviivaista class Asiakas { } String tunnus; String nimi; Set<Laskutustieto> laskutustiedot; class Laskutustieto { } int tilinumero; boolean luottotili; decimal summa; Asiakas omistaja; 9

SQL-taulurakenteen luomislausekkeet create table ASIAKAS ( ); TUNNUS VARCHAR(15) NOT NULL PRIMARY KEY, NIMI VARCHAR(50) NOT NULL, SALASANA CHAR(32) NOT NULL create table LASKUTUSTIETO ( TILINUMERO INT NOT NULL PRIMARY KEY, LUOTTOTILI BOOLEAN, RAHAMAARA DECIMAL(10, 3), OMISTAJA FOREIGN KEY REFERENCES ASIAKAS ); 10

Oliomallin relaatiovastineet moniselitteisiä Edellisessä esimerkissä ei tunnettu asiakkaan osoitetta Vakiotapa osoitteen mallintamiseen on käyttää kompositiota Miten relaatiomalli muuttuu? Ovatko Osoite-luokan kentät Asiakas-taulun sarakkeita? Vai oma erillinen taulunsa, viittaukset viiteavaimin? Olio/relaatiomallin epäyhteensopivuus yleistä 11

Olio- ja relaatioparadigmojen epäyhteensopivuus Olio- ja relaatiomallien yhteensovittamisessa syntyviä ongelmia syntyy esim. seuraavista: Mallinnuksen tarkkuustasosta (granularity) Luokkahierarkioiden tallennustavassa Olioiden identiteettiongelmat Yhteyksien tallennustavasta Yhteyksien navigoituvuustavoissa Joidenkin arvioiden mukaan jopa 30% oliojärjestelmän koodiriveistä voi olla puuduttavaa, toisteista olio- ja relaatiomuunnosten toteuttamista 12

Mallinnuksen tarkkuustaso-ongelma Oliomallinnuksessa voidaan tietosisältöä jakaa luokkiin vapaasti tarpeen mukaan Relaatiomallinnuksessa käytetään jaotellaan taulu sarakkeisiin ja riveihin uusien tietotyyppien esitteleminen monesti vaikeaa, järjestelmäkohtaista create table ASIAKAS ( ); TUNNUS VARCHAR(15) NOT NULL PRIMARY KEY, NIMI VARCHAR(50) NOT NULL, SALASANA CHAR(32) NOT NULL OSOITE_KATUOSOITE VARCHAR(50), OSOITE_KUNTA VARCHAR(15), OSOITE_POSTINUMERO CHAR(5), 13

Luokkahierarkian tallennusongelma Luokkahierarkian laajennosmekanismille ei ole suoraa vastinetta relaatiomallissa Kukin aliluokka määrittelee oman tietosisältönsä, vaikuttaa taulujen rakenteeseen Kullakin oliolla on luokkansa, vaikuttaa taulujen rakenteeseen Taulujen viiteavaimet voivat osoittaa vain yhteen viitattuun tauluun 14

Olioidentiteetin ongelma Asiakkaan identifioivaksi kentäksi määriteltiin käyttäjätunnus Esim. Javassa olioita voidaan tunnistaa viitesamuuden ja identiteettisamuuden kannalta Viitesamuus: ab == bc Identiteettisamuus: ab.equals(bc) Tietokannan identiteettikenttä tuo kolmannen samuuden käsitteen Esimerkiksi tietojen muokkaustilanteessa voi järjestelmässä olla olioita, jotka viite- ja identiteettitasolla ovat eriäviä, mutta tietokannan kannalta samoja 15

Yhteyksien tallennustapaongelma UML:ssä on mahdollista merkitä navigoituvuussääntöjä Vastaavat olion hallussaan pitämää viitettä Olioviite aina yksisuuntainen Molempiin suuntiin navigoitavat yhteydet toteutetaan kahtena olioviitteenä Relaatiokannassa viitteet ovat luonnostaan kaksisuuntaisia Viiteavain viittaa toisen taulun pääavaimeen 16

Olioverkkojen navigoituvuusongelma Olio-ohjelmalle on luontaista käsitellä olioverkkoja ja delegoida palvelun toteuttaminen osaolioille Etukäteen palvelun toteuttamiseen osallistuvien olioiden tunnistaminen vaikeaa Kunkin olion noutaminen tietokannasta siinä vaiheessa, kun olion palveluita tarvitaan, on tehotonta ns. n+1 kyselyn ongelma 17

Olio/relaatiomallin kuvausten käyttäminen Olio- ja relaatiomallien välisten yhteyksien kuvaamisen käytetään monesti erillistä työkalua ORM-kuvaus määrittelee miten oliomalli esitetään relaatiokannassa ORM-työkalu sisältää rajapinnat olioiden tietokannasta lataamiseksi ja tallentamiseksi Javassa standardi Java Persistence API (JPA) 18

ORM-työkalun ongelmakenttä ORM-työkalun käytännöt vastaavat mm. seuraaviin kysymyksiin: Minkälainen rakenne pysyväisluokilla tulee olla Miten O/R-kuvaukset esitetään Miten periytymisrakenteet tallennetaan Olioidentiteettiin liittyvät kysymykset Miten sovelluslogiikka kudotaan tallennuskerroksen kanssa yhteen Mikä on pysyväisluokkien olioiden elinkaari Miten pysyväisolioita noudetaan tietokannasta Miten pysyväisolioverkkoja noudetaan tehokkaasti 19

Hello World-esimerkki Hibernatella Hibernate on ehkäpä käytetyin ORM-toteutus Javaympäristössä Alkuperäinen JPA-määrittely perustuu Hibernaten esittelemiin rajapintoihin Esimerkiksi linkitetyn viestilistan tallentaminen Hibernatella 20

Olioita voidaan käsitellä normaalisti public class HoiMaailma1 { public static void main(string args[]) { } } Message msg = new Message( Terve maailma ); System.out.println(msg.getText()); 21

Tietokantakäytössä sessiot ja transaktiot Tietokantaa käytettäessä tietokannan hallintajärjestelmä erottelee eri käyttäjien muutokset kannan sisältöön Muutokset tietokantaan jaetaan erillisiin transaktioihin Hibernate käyttää sisäistä session käsitettä tietokantayhteyden ohessa { Session session = getsessionfactory().opensession(); Transaction tx = session.begintransaction(); Message msg = new Message( Terve kaverit! ); } session.save(msg); tx.commit(); session.close() 22

Luokkien kuvaus tietokantatauluiksi Luokkien tallennustapa tietokantaan kuvataan XMLkuvauksin, esim: <hibernate-mapping> <class name= Message table= MESSAGES > <id name= id column= MSG_ID > <generator class= increment /> </id> <property name= text column= MSG_TEXT /> <many-to-one name= nextmessage cascade= all column= NEXT_MESSAGE_ID /> </class> </hibernate-mapping> 23

Vastaava tietokantakaavio Relaatiotietokannasta löytyvien taulujen tulisi vastata luokkakuvauksia Mahdollista käyttää luokkakuvauksista automaattisesti tuotettua taulukaaviota Hello-world esimerkissä: 24

Olioiden tietojen lataaminen Olioiden tietokantaan talletettu tila voidaan ladata sessiota käyttäen: { Session session = HibernateUtil.getSessionFactory().openSession(); Transaction newtransaction = session.begintransaction(); List messages = session.createquery("from Message").list(); System.out.println(messages.size() + " message(s) found:"); for (Iterator iter = messages.iterator(); iter.hasnext();) { Message msg = (Message) iter.next(); System.out.println("[" + msg.getid() + "]: " + msg.gettext()); } } newtransaction.commit(); session.close(); 25

Olioiden tietojen päivittäminen Muistissa olevien olioiden tietoja voidaan päivittää session kautta: { } Session session = HibernateUtil.getSessionFactory().openSession(); Transaction newtransaction = session.begintransaction(); Message oldmsg = (Message) session.load(message.class, msgid); oldmsg.settext(newmsg); newtransaction.commit(); newsession.close(); 26

Kirjastojärjestelmän toinen iteraatio Toteutetaan järjestelmän käsittelemä data pysyväksi Toteutus tehdään Hibernate-kehystä hyödyntäen Esitellään ensi viikolla ohjelmointieksperimentissä Ohjelmointieksperimentissä osallistujia pyydetään tutustumaan toisen iteraation lopputuloksena syntyneeseen ohjelmistoon Ja tekemään muutamia ylläpidollisia muutoksia siihen Kullakin osallistujalla omanlaisensa versio, tutkimuksen kohteena eri toteutusrakenteiden vaikutus ohjelmiston ylläpidettävyyteen 27