CS-A1150 Tietokannat CS-A1150 Tietokannat / 39
|
|
- Anja Lahti
- 6 vuotta sitten
- Katselukertoja:
Transkriptio
1 CS-A1150 Tietokannat CS-A1150 Tietokannat / 39
2 Oppimistavoitteet: tämän luennon jälkeen Tunnet SQL:n perusteet ja osaat tehdä yksinkertaisia SQL-kyselyitä, esimerkiksi hakea relaatiosta halutun ehdon täyttävät monikot ja niistä halutut attribuutit (valinta ja projektio) yhdistää kahden tai useamman relaation monikoita ja haetaan niistä halutun ehdon toteuttavat yhdistelmät (liitos) järjestää kyselyn tulokset tehdä erilaisia joukko-operaatioita vaativia kyselyitä. CS-A1150 Tietokannat / 39
3 SQL Tyypillisiä tietokantojen tarvitsemia toimenpiteitä Uusien relaatioiden (taulujen) määrittelminen. Tietueiden (monikoiden) lisääminen tietokantaan. Tietueiden tietojen päivitys. Kyselyjen tekeminen tietokannasta. Näiden toimenpiteiden tekemiseen relaatiotietokannoissa voi käyttää SQL-kieltä (Structured Query Language) Kieli kehitettiin 1970-luvulla, ja sen on nykyisin käytössä lähes kaikissa suurissa kaupallisissa tietokannan hallintajärjestelmissä. CS-A1150 Tietokannat / 39
4 Eri SQL-murteita ANSI SQL eli SQL1 vuodelta 1986 SQL2 vuoden 1992 standardi laajennettu SQL1:stä, uusina piirteinä esim. typpit DATE ja TIME, erilaisia uusia operaatioita atomisille tietotyypeille, uusia joukko- ja liitosoperaatioita jne. SQL-99 eli SQL:1999 Tunnettu myös SQL3-nimellä Laajennettu SQL2:sta (esim. rekursio, laukaisimet ja oliot) Standardia on myöhemmin laajenettu (SQL:2003, SQL:2006, SQL:2008, SQL:2011, SQL:2016). Ohjelmistotuottajien SQL-murteet ovat tyypillisesti SQL2:n laajennoksia SQL3:n piirteillä. Tällä kurssilla harjoitustehtävissä ja harjoitustyössä käytettävä SQLite toteuttaa lähes kaikki SQL2:n piirteet. CS-A1150 Tietokannat / 39
5 SQL:n kyselyt SQL:n kyselyt ovat deklaratiivisia: Ne kertovat, mihin kysymykseen halutaan vastaus, mutta eivät määrittele sitä, miten kysely käytännössä suoritetaan. Kyselyn käytännön suorittamisen suunnittelu jää tietokannan hallintajärjestelmän kyselynoptimoijan tehtäväksi. Kyselyn perusmuoto on SELECT <attribuuttilista> FROM <relaatiolista> WHERE ehto FROM-osa ilmaisee, mihin relaatioon/relaatioihin kysely kohdistuu (vrt. karteesinen tulo). SELECT-osa määrää, mitkä attribuutit tulostetaan tulokseen valituista monikoista (vrt. projektio). WHERE-osa ilmaisee ehdon, jonka kyselyn tulokseen valitun monikon pitää täyttää (vrt. valinta). CS-A1150 Tietokannat / 39
6 Esimerkkitietokanta Tämän luennon esimerkit käsittelevät verkkokaupan esimerkkitietokantaa, joka koostuu seuraavista relaatioista Customers(custNo, name, born, bonus, address, ) Products(number, prodname, description, price, manufid) Manufacturers(ID, manufname, phone) Orders(orderNo, deliver, status, custno) BelongsTo(orderNo, productno, count) Oletetaan, että relaation Products sisältö on tällä hetkellä seuraava: Relation Products number prodname description price manufid T Samsung Galaxy A5 cellphone S123 R IPad Air 2 tablet M554 T Superstar Track M jacket 30.0 A432 S Brasserie 24 pan F542 CS-A1150 Tietokannat / 39
7 Esimerkkitietokannan selityksiä Relaatioon Customers on tallennettu verkkokaupan asiakkaiden tietoja. Attribuutteina ovat asiakkaan asiakasnumero, nimi, syntymävuosi, bonuspisteet, osoite ja sähköpostiosoite. Relaatioon Products on kerätty verkkokaupan tuotteiden tietoja. Attribuutteina ovat tuotenumero, tuotteen nimi, kuvaus (esim. camera ), hinta ja valmistajan yksilöivä tunnus. Relaatio Manufacturers sisältää valmistajien tietoja. Attribuutteina ovat valmistajan tunnus, nimi ja puhelinnumero. Relaatiossa Orders säilytetään tietoa tehdyistä tilauksista. Yksi tilaus voi sisältää monta tuotetta. Attribuutteina ovat tilausnumero, toimitustapa, tilauksen tila ja tilauksen tehneen asiakkaan asiakasnumero. Relaatio BelongsTo sisältää tiedon siitä, mikä tuote kuuluu mihinkin tilaukseen. Attribuutteina ovat tilauksen numero, yhden tilaukseen kuuluvan tuotteen numero ja tieto siitä, kuinka monta kappaletta ko. tuotetta sisältyy tilaukseen. CS-A1150 Tietokannat / 39
8 Yksinkertainen SQL-kysely Tarkastellaan ensimmäisenä kyselyä SELECT description, price FROM Products; Tulosrelaatiossa on samat tuotteet kuin alkuperäisessä relaatiossa, mutta niistä esitetään vain kaksi attribuuttia: Result description price cellphone tablet jacket 30.0 pan CS-A1150 Tietokannat / 39
9 Ehto mukaan SQL-kyselyyn Haetaan edellisestä Products-taulusta niiden tuotteiden nimet ja kuvaukset, joiden hinta on alle 35 euroa: SELECT prodname, description FROM Products WHERE price < 35.0; Kysely siis käy läpi kaikki Products-relaation monikot, valitsee niistä annetun ehdon toteuttavat monikot ja tulostaa näistä SELECT-osassa luetellut attribuutit. (Kyselyä ei välttämättä suoriteta juuri tällä tavalla, mutta lopputulos on sama.) Tulos on nyt Result prodname Superstar Track M Brasserie 24 description jacket pan CS-A1150 Tietokannat / 39
10 Välitehtävä 1 Kirjoita seuraava kysely SQL:llä: hae kaikkien niiden asiakkaiden asiakasnumerot ja nimet, joilla on vähintään 30 bonuspistettä. CS-A1150 Tietokannat / 39
11 Välitehtävä 1, ratkaisu Hae kaikkien niiden asiakkaiden asiakasnumerot ja nimet, joilla on vähintään 30 bonuspistettä. SELECT custno, name FROM Customers WHERE bonus >= 30; CS-A1150 Tietokannat / 39
12 Toinen esimerkki valinnasta Haetaan relaatiosta Products niiden tuotteiden nimet ja hinnat, joiden kuvaus on cellphone tai tablet ja joiden hinta on alle 400 euroa. SELECT prodname, price FROM Products WHERE (description = cellphone OR description = tablet ) AND price < 400.0; Tulos Result prodname price Samsung Galaxy A CS-A1150 Tietokannat / 39
13 Liitokset Liitos voidaan toteuttaa helposti kirjoittamalla kyselyn WHERE-osaan ehto, joka koskee kahden eri relaation attribuutteja Esimerkki: oletetaan, että relaation Manufacturers sisältö on seuraava: Relation Manufactures ID manufname phone R122 Nike M554 Apple S123 Samsung L711 Sony F542 Fiskars A432 Adidas Kirjoitetaan kysely "tulosta tietokannassa olevien tuotteiden nimet yhdessä kunkin tuotteen valmistajan nimen kanssa." CS-A1150 Tietokannat / 39
14 Liitokset, jatkuu Tulosta tietokannassa olevien tuotteiden nimet yhdessä kunkin tuotteen valmistajan nimen kanssa. SELECT prodname, manufname FROM Products, Manufacturers WHERE manufid = ID; Kysely voidaan ajatella suoritettavaksi seuraavasti: 1. Muodostetaan FROM-osassa olevien relaatioiden karteesinen tulo: kaikki mahdolliset monikot, joiden ensimmäisenä osana on jokin relaation Products monikko ja toisena osana jokin relaation Manufactures monikko. 2. Valitaan karteesisen tulon monikoista ne, jotka toteuttavat WHERE-osassa olevan ehdon. 3. Otetaan tulokseen mukaan valituista monikoista vain ne attribuutit, jotka on lueteltu SELECT-osassa. Oikeasti kyselyä ei välttämättä suoriteta näin. Lopputulos on kuitenkin sama, ja SQL-kyselyn voi ymmärtää helposti ajattelemalla sitä näin. CS-A1150 Tietokannat / 39
15 Liitokset, jatkuu Esimerkki: muodostetaan karteesinen tulo: number prodname description price manufid ID manufname phone T Samsung Galaxy A5 cellphone S123 R122 Nike T Samsung Galaxy A5 cellphone S123 M554 Apple T Samsung Galaxy A5 cellphone S123 S123 Samsung T Samsung Galaxy A5 cellphone S123 L711 Sony T Samsung Galaxy A5 cellphone S123 F542 Fiskars T Samsung Galaxy A5 cellphone S123 A432 Adidas R IPad Air 2 tablet M554 R122 Nike R IPad Air 2 tablet M554 M554 Apple R IPad Air 2 tablet M554 S123 Samsung R IPad Air 2 tablet M554 L711 Sony R IPad Air 2 tablet M554 F542 Fiskars R IPad Air 2 tablet M554 A432 Adidas T Superstar Track M jacket 30.0 A432 R122 Nike T Superstar Track M jacket 30.0 A432 M554 Apple T Superstar Track M jacket 30.0 A432 S123 Samsung T Superstar Track M jacket 30.0 A432 L711 Sony T Superstar Track M jacket 30.0 A432 F542 Fiskars T Superstar Track M jacket 30.0 A432 A432 Adidas S Brasserie 24 pan F542 R122 Nike S Brasserie 24 pan F542 M554 Apple S Brasserie 24 pan F542 S123 Samsung S Brasserie 24 pan F542 L711 Sony S Brasserie 24 pan F542 F542 Fiskars S Brasserie 24 pan F542 A432 Adidas CS-A1150 Tietokannat / 39
16 Liitokset, jatkuu Valitaan ehdon täyttävät monikot: number prodname description price manufid ID manufname phone T Samsung Galaxy A5 cellphone S123 R122 Nike T Samsung Galaxy A5 cellphone S123 M554 Apple T Samsung Galaxy A5 cellphone S123 S123 Samsung T Samsung Galaxy A5 cellphone S123 L711 Sony T Samsung Galaxy A5 cellphone S123 F542 Fiskars T Samsung Galaxy A5 cellphone S123 A432 Adidas R IPad Air 2 tablet M554 R122 Nike R IPad Air 2 tablet M554 M554 Apple R IPad Air 2 tablet M554 S123 Samsung R IPad Air 2 tablet M554 L711 Sony R IPad Air 2 tablet M554 F542 Fiskars R IPad Air 2 tablet M554 A432 Adidas T Superstar Track M jacket 30.0 A432 R122 Nike T Superstar Track M jacket 30.0 A432 M554 Apple T Superstar Track M jacket 30.0 A432 S123 Samsung T Superstar Track M jacket 30.0 A432 L711 Sony T Superstar Track M jacket 30.0 A432 F542 Fiskars T Superstar Track M jacket 30.0 A432 A432 Adidas S Brasserie 24 pan F542 R122 Nike S Brasserie 24 pan F542 M554 Apple S Brasserie 24 pan F542 S123 Samsung S Brasserie 24 pan F542 L711 Sony S Brasserie 24 pan F542 F542 Fiskars S Brasserie 24 pan F542 A432 Adidas CS-A1150 Tietokannat / 39
17 Liitokset, jatkuu Valitaan ehdon täyttävistä monikoista pyydetyt attribuutit: number prodname description price manufid ID manufname phone T Samsung Galaxy A5 cellphone S123 S123 Samsung R IPad Air 2 tablet M554 M554 Apple T Superstar Track M jacket 30.0 A432 A432 Adidas S Brasserie 24 pan F542 F542 Fiskars Result prodname Samsung Galaxy A5 IPad Air 2 Superstar Track M Brasserie 24 manufname Samsung Apple Adidas Fiskars CS-A1150 Tietokannat / 39
18 Miten lähden tekemään SQL-kyselyä? 1. Mieti, mistä relaatioista tarvitset tietoa, jotta saisit halutun vastauksen. Kirjoita näiden relaatioiden nimet FROM-osaan. 2. Kuvittele, että sinulla on näiden relaatioiden monikoista kaikki mahdolliset yhdistelmät. Mitkä yhdistelmät otetaan mukaan vastaukseen? Kirjoita tätä vastaava(t) ehto/ehdot WHERE-osaan. Jos ehtoja on useampi kuin yksi, tarvitset loogisia operaattoreita AND tai OR. 3. Mitä muita ehtoja kysely vaatii toteutettavaksi? Lisää tätä vastaava ehto/ehdot WHERE-osaan. Yhdistä ehdot tilanteeseen sopivilla loogisilla operaattoreilla. 4. Mitä attribuutteja vastaukseen otetaan mukaan? Kirjoita näiden attribuuttien nimet SELECT-osaan. CS-A1150 Tietokannat / 39
19 Toinen esimerkki liitoksesta Kysely: "tulosta niiden valmistajien nimet, joilla on tarjolla alle 300 euroa maksavia tuotteita, joiden kuvaus on cellphone". Kysely SQL:llä: SELECT manufname FROM Products, Manufacturers WHERE manufid = ID AND description = cellphone AND price < 300; Tulos esimerkkirelaatioilla: Result manufname Samsung CS-A1150 Tietokannat / 39
20 Duplikaattien poistaminen Toisin kuin relaatioalgebrassa, SQL:ssä tulosrelaatiot eivät ole joukkoja (set), vaan monijoukkoja (bag), eli sama monikko voi esiintyä tuloksessa monta kertaa. Oletetaan, että relaatio Customers on seuraava Relation Customers number name born bonus address Teemu Teekkari Servinkuja 3 tteekkari@gmail.com Riina Raksalainen Otaranta 8 riinar@yahoo.com Antti Virta Aaltokatu 4 antti@hotmail.com Nina Teekkari Servinkuja 3 nite@hotmail.com CS-A1150 Tietokannat / 39
21 Duplikaattien poistaminen, jatkoa Suoritetaan sille kysely SELECT address FROM Customers WHERE bonus > 15; Tulos on Result address Servinkuja 3 Otaranta 8 Servinkuja 3 CS-A1150 Tietokannat / 39
22 Duplikaattien poistaminen, jatkoa Jos duplikaatit halutaan poistaa, on SELECT-osaan lisättävä määre DISTINCT: SELECT DISTINCT address FROM Customers WHERE bonus > 15; Tämän kyselyn vastaus on Result address Servinkuja 3 Otaranta 8 CS-A1150 Tietokannat / 39
23 Attribuuttien yksiselitteisyys Eri relaatioissa voi olla samannimisiä attribuutteja. Jos kysely kohdistuu tällaisiin relaatioihin, pitää yksikäsitteisesti määrätä, minkä relaation attribuutteja tarkoitetaan. Samannimiset attribuutit erotetaan toisistaan pistenotaatiolla: attribuutin alkuun liitetään sen relaation nimi. Esim. R.A tarkoittaa relaation R attribuuttia A. Esimerkki: Halutaan löytää relaatioista Customers(custNo, name, born, bonus, address, ) Orders(orderNo, deliver, status, custno) niiden asiakkaiden asiakasnumerot ja nimet, joilla on tilaus, jonka status on returned. CS-A1150 Tietokannat / 39
24 Attribuuttien yksiselitteisyys, jatkoa Kysely: SELECT Customers.custNo, name FROM Customers, Orders WHERE Customers.custNo = Orders.custNo AND status = returned ; CS-A1150 Tietokannat / 39
25 Rivimuuttujat Pistenotaation käyttö yksistään ei riitä, jos kyselyssä pitää verrata saman relaation rivejä keskenään. Esimerkki: halutaan tulostaa asiakkaat, jotka asuvat keskenään samassa osoitteessa. Tällöin on verrattava kahta saman Customers-relaation riviä keskenään. SQL:ssä voidaan käyttää rivimuuttujia (engl. tuple variables) viittaamaan relaatioihin relaatioalgebran uudelleennimeämisen tapaan. Samalle relaatiolle voi määritellä useita rivimuuttujia Rivimuuttujat määritellään FROM-osassa käyttämällä syntaksia FROM <relaation nimi> AS <rivimuuttujan nimi> CS-A1150 Tietokannat / 39
26 Rivimuuttujat, jatkoa Tulosta asiakkaat, jotka asuvat samassa osoitteessa keskenään. SELECT C1.name, C2.name FROM Customers AS C1, Customers AS C2 WHERE C1.address = C2.address AND C1.custNo < C2.custNo; Rivimuuttujan voi määritellä myös ilman AS-ilmausta: SELECT C1.name, C2.name FROM Customers C1, Customers C2 WHERE C1.address = C2.address AND C1.custNo < C2.custNo; Rivimuuttujia voidaan käyttää myös vähentämään kirjoitustyötä kyselyissä silloinkin, kun niiden käyttö ei ole varsinaisesti välttämätöntä. CS-A1150 Tietokannat / 39
27 Esimerkki kolmen relaation liitoksesta Halutaan niiden tilausten numerot ja tilat, joihin kuuluu tuote, jonka kuvaus on cellphone. Kysely SELECT O.orderNo, status FROM Orders AS O, Products AS P, BelongsTo AS B WHERE O.orderNo = B.orderNo AND number = productno AND description = cellphone ; CS-A1150 Tietokannat / 39
28 Tulosrelaation rivien esitysjärjestyksen määrääminen Oletusarvoisesti kyselyn tulosrelaation rivit esitetään satunnaisessa järjestyksessä. Järjestys voi myös vaihdella kyselyn eri suorituskertojen välillä. Jos tulosrelaation rivit halutaan järjestää jonkin attribuutin mukaan, saadaan se aikaan lisäämällä kyselyyn määre ORDER BY <attribuuttilista> Tällöin tulosrelaatio järjestetään ensisijaisesti listan 1. attribuutin mukaan, toisijaisesti listan 2. attribuutin mukaan jne. Järjestys on oletusarvoisesti kasvava, mutta sen voi vaihtaa laskevaksi lisäämällä attribuutin jälkeen sanan DESC. CS-A1150 Tietokannat / 39
29 Esimerkki järjestyksen määräämisestä Tulostetaan asiakkaat, joilla on yli 30 bonuspistettä, bonuspisteiden määräämässä järjestyksessä (suurin ensin). Jos useammalla asiakkaalla on sama määrä bonuspisteitä, tulostetaan nämä syntymävuoden määräämässä järjestyksessä (pienin ensin). SELECT-osassa käytetty * valitsee kyselyyn mukaan kaikki relaation attribuutit Kysely SELECT FROM Customers WHERE bonus > 30 ORDER BY bonus DESC, born; CS-A1150 Tietokannat / 39
30 WHERE-osasssa käytettävistä operaattoreista WHERE-osa voi sisältää vertailuoperaattoreita =, <> (erisuuruus), <, >, <= ja >=. Vertailtavat arvot voivat olla vakioita tai kyselyn FROM-osassa määriteltyjen relaatioiden attribuutteja. Vertailussa voidaan käyttää myös aritmeettisia operaattoreita +, -, * ja /. Esimerkiksi ehto (born ) * (born -1995) < 100 on tosi vuosille Mahdollisia loogisia operaattoreita ovat AND, OR ja NOT. CS-A1150 Tietokannat / 39
31 Välitehtävä 2 Kirjoita seuraava kysely: tulosta niiden asiakkaiden asiakasnumerot, joilla on useampi kuin yksi tilaus. Kyselyn pitää tulostaa asiakasnumerot järjestyksessä. CS-A1150 Tietokannat / 39
32 Välitehtävä 2, ratkaisu Tulosta niiden asiakkaiden asiakasnumerot, joilla on useampi kuin yksi tilaus. Kyselyn pitää tulostaa asiakasnumerot järjestyksessä. SELECT O1.custNo FROM Orders AS O1, Orders AS O2 WHERE O1.custNo = O2.custNo AND O1.orderNo <> O2.orderNo ORDER BY O1.custNo; Vastauksessa voi olla duplikaatteja. Ne voidaan haluttaessa poistaa DISTINCT-ilmauksella. CS-A1150 Tietokannat / 39
33 Merkkijonojen vertailusta Myös merkkijonojen vertailuun voidaan käyttää operaattoreita =, <> (erisuuruus), <, >, <= ja >=. Tällöin tutkitaan merkkijonojen leksikografista järjestystä. Sen lisäksi merkkijonojen samankaltaisuutta voidaan tutkia LIKE-vertailuoperaattorin avulla. Vertailulauseke on muotoa s LIKE p s on merkkijono ja p rakennekaava (pattern), joka voi sisältää tavallisten merkkien lisäksi erikoismerkkejä % ja _. p:ssä esiintyvä % ilmaisee, että vastaavalla paikalla s:ssä voi esiintyä mikä tahansa nollan tai useamman merkin pituinen merkkijono. p:ssä esiintyvä _ ilmaisee, että vastaavalla paikalla s:ssä voi esiintyä mikä tahansa yksittäinen merkki. Lauseke s LIKE p on tosi, jos ja vain jos s toteuttaa rakennekaavan p. CS-A1150 Tietokannat / 39
34 Esimerkkejä merkkijonojen vertailuista Kysely SELECT prodname, description FROM Products WHERE description LIKE cell ; etsii tuotteet, joiden kuvaus on yhdeksän merkin mittainen siten, että neljä ensimmäistä merkkiä ovat cell ja niiden jälkeen tulee täsmälleen viisi merkkiä, jotka voivat olla mitä tahansa. Kysely SELECT prodname, description FROM Products WHERE prodname LIKE %Galaxy% ; etsii tuotteet, joiden nimessä esiintyy jossain kohdassa peräkkäin kirjaimet Galaxy. CS-A1150 Tietokannat / 39
35 Aritmeettinen lauseke SELECT-osassa Esimerkki: halutaan tuotteiden nimet ja hinnat niin, että hinnat on muutettu dollareiksi kertomalla ne 1.2:llä Tällöin SELECT-osaan voidaan kirjoittaa kertolasku, jolla eurot voidaan muuttaa dollareiksi: SELECT prodname, price 1.2 FROM Products; Tuloksen otsikko on tällöin prodname price * 1.2 Jos haluaa kauniimman otsikon, kannattaa lauseke nimetä SELECT-osassa uudelleen: SELECT prodname, price 1.2 AS dollarprice FROM Products; CS-A1150 Tietokannat / 39
36 Yhdiste SQL-kyselyssä on mahdollista suorittaa joukko-operaatioita yhdiste, leikkaus ja erotus kyselyiden tuloksina syntyviin relaatioihin. Toisin kuin muissa SQL-kyselyissä, joukko-operaatioiden tulokset ovat aitoja joukkoja eli duplikaatit on poistettu. (Duplikaattien poiston voi kuitenkin estää kirjoittamalla kyselyyn sanan ALL joukko-operaation nimen jälkeen.) Esimerkki: halutaan esimerkkitietokannasta sekä kaikkien niiden asiakkaiden numerot, joiden tilauksen status on waiting, että kaikkien niiden asiakkaiden numerot, joiden osoitteessa esiintyy sana Servinkuja. SELECT CustNo FROM Orders WHERE status = waiting UNION SELECT CustNo FROM Customers WHERE address LIKE %Servinkuja% ; CS-A1150 Tietokannat / 39
37 Leikkaus Esimerkki: halutaan niiden valmistajien nimet, joilta verkkokaupassa on tarjolla sekä matkapuhelimia että kameroita. SELECT manufname FROM Manufacturers, Products WHERE manufid = ID and description = camera INTERSECT SELECT manufname FROM Manufacturers, Products WHERE manufid = ID and description = cellphone ; CS-A1150 Tietokannat / 39
38 Erotus Joukkojen erotus esitetään SQL:ssä operaation EXCEPT avulla. Esimerkki: halutaan niiden valmistajien nimet, joilta verkkokaupassa on tarjolla kameroita, mutta ei matkapuhelimia. SELECT manufname FROM Manufacturers, Products WHERE manufid = ID and description = camera EXCEPT SELECT manufname FROM Manufacturers, Products WHERE manufid = ID and description = cellphone ; CS-A1150 Tietokannat / 39
39 Attribuuttien nimeäminen uudelleen joukko-operaatioiden yhteydessä Esimerkki: halutaan esimerkkitietokannasta sekä kaikkien A:lla alkavien asiakkaiden nimet että kaikki A:lla alkavien valmistajien nimet. Ongelma: Customers-relaatiossa nimeä kuvaavan attribuutin nimi on name, mutta Manufacturers-relaatiossa nimeä kuvaavan attribuutin nimi on manufname. Halutaan, että tulosrelaatiossa attribuutilla on sama nimi. Ongelma voidaan ratkaista nimeällä toisen kyselyn tuloksessa attribuutti uudelleen: SELECT name FROM Customers WHERE name LIKE A% UNION SELECT manufname AS name FROM Manufacturers WHERE name LIKE A% ; CS-A1150 Tietokannat / 39
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 23.2.2016 CSE-A1200 Tietokannat 23.2.2016 1 / 36 Oppimistavoitteet: tämän luennon jälkeen Tunnet SQL:n perusteet ja osaat tehdä yksinkertaisia SQL-kyselyitä, esimerkiksi hakea relaatiosta
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 22.3.2016 CSE-A1200 Tietokannat 22.3.2016 1 / 35 Oppimistavoitteet: tämän luennon jälkeen Osaat tehdä SQL:llä kyselyitä, jotka käyttävät hyväkseen toisen kyselyn tuloksia (alikyselyt).
CS-A1150 Tietokannat CS-A1150 Tietokannat / 34
CS-A1150 Tietokannat 7.2.2017 CS-A1150 Tietokannat 7.2.2017 1 / 34 Oppimistavoitteet: tämän luennon jälkeen Tiedät, mitä tarkoitetaan relaatioalgebralla. Osaat tehdä erilaisia kyselyitä relaatioalgebran
CS-A1150 Tietokannat CS-A1150 Tietokannat / 34
CS-A1150 Tietokannat 6.2.2018 CS-A1150 Tietokannat 6.2.2018 1 / 34 Oppimistavoitteet: tämän luennon jälkeen Tiedät, mitä tarkoitetaan relaatioalgebralla. Osaat tehdä erilaisia kyselyitä relaatioalgebran
SQL-perusteet, SELECT-, INSERT-, CREATE-lauseet
SQL-perusteet, SELECT-, INSERT-, CREATE-lauseet A271117, Tietokannat Teemu Saarelainen teemu.saarelainen@kyamk.fi Lähteet: Leon Atkinson: core MySQL Ari Hovi: SQL-opas TTY:n tietokantojen perusteet-kurssin
CS-A1150 Tietokannat CSE-A1150 Tietokannat / 39
CS-A1150 Tietokannat 9.5.2017 CSE-A1150 Tietokannat 9.5.2017 1 / 39 Kertausluento Tällä luennolla kerrataan lyhyesti tenttivaatimuksissa esitettyjä asioita ja samalla tarkastellaan sitä, mitä niistä voidaan
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 29.3.2016 CSE-A1200 Tietokannat 29.3.2016 1 / 40 Oppimistavoitteet: tämän luennon jälkeen Tiedät, miten tietokannan relaatioiden (taulujen) määrittelyt kirjoitetaan SQL:llä. Osaat
CS-A1150 Tietokannat CS-A1150 Tietokannat / 43
CS-A1150 Tietokannat 27.3.2018 CS-A1150 Tietokannat 27.3.2018 1 / 43 Oppimistavoitteet: tämän luennon jälkeen Tiedät, miten tietokannan relaatioiden (taulujen) määrittelyt kirjoitetaan SQL:llä. Osaat päivittää
CS-A1150 Tietokannat CSE-A1150 Tietokannat / 29
CS-A1150 Tietokannat 20.5.2019 CSE-A1150 Tietokannat 20.5.2019 1 / 29 Kertausluento Tällä luennolla kerrataan lyhyesti tenttivaatimuksissa esitettyjä asioita ja samalla tarkastellaan sitä, mitä niistä
CS-A1150 Tietokannat CS-A1150 Tietokannat / 44
CS-A1150 Tietokannat 2.4.2019 CS-A1150 Tietokannat 2.4.2019 1 / 44 Oppimistavoitteet: tämän luennon jälkeen Tiedät, miten tietokannan taulujen (relaatioiden) määrittelyt kirjoitetaan SQL:llä. Osaat päivittää
SELECT-lauseen perusmuoto
SQL: Tiedonhaku SELECT-lauseen perusmuoto SELECT FROM WHERE ; määrittää ne sarakkeet, joiden halutaan näkyvän kyselyn vastauksessa sisältää
CS-A1150 Tietokannat CS-A1150 Tietokannat / 44
CS-A1150 Tietokannat 12.3.2019 CS-A1150 Tietokannat 12.3.2019 1 / 44 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa UML-kaavion relaatiomalliin. Toisin sanoen: jos sinulla on valmis UML-kaavio,
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 10.5.2016 CSE-A1200 Tietokannat 10.5.2016 1 / 50 Kertausluento Tällä luennolla kerrataan lyhyesti tenttivaatimuksissa esitettyjä asioita ja samalla tarkastellaan sitä, mitä niistä
CS-A1150 Tietokannat CSE-A1150 Tietokannat / 32
CS-A1150 Tietokannat 15.5.2018 CSE-A1150 Tietokannat 15.5.2018 1 / 32 Kertausluento Tällä luennolla kerrataan lyhyesti tenttivaatimuksissa esitettyjä asioita ja samalla tarkastellaan sitä, mitä niistä
TIEDONHALLINTA - SYKSY Luento 10. Hannu Markkanen /10/12 Helsinki Metropolia University of Applied Sciences
TIEDONHALLINTA - SYKSY 2011 Kurssikoodi: Saapumisryhmä: Luento 10 TU00AA48-2002 TU10S1E Hannu Markkanen 14.-15.11.2011 9/10/12 Helsinki Metropolia University of Applied Sciences 1 SQL: Monen taulun kyselyt
CS-A1150 Tietokannat CS-A1150 Tietokannat / 35
CS-A1150 Tietokannat 5.3.2019 CS-A1150 Tietokannat 5.3.2019 1 / 35 Oppimistavoitteet: tämän luennon jälkeen Osaat tehdä tietokantaa kuvaavan mallin UML-kaavion avulla. Tunnet esimerkiksi seuraavat UML-mallinnuksen
CS-A1150 Tietokannat CS-A1150 Tietokannat / 43
CS-A1150 Tietokannat 15.4.2019 CS-A1150 Tietokannat 15.4.2019 1 / 43 Oppimistavoitteet: tämän luennon jälkeen Tiedät, mitä tarkoitetaan hakemistolla ja mitä hyötyä hakemistosta on. Tiedät, miten voidaan
CS-A1150 Tietokannat CS-A1150 Tietokannat / 51
CS-A1150 Tietokannat 7.3.2017 CS-A1150 Tietokannat 7.3.2017 1 / 51 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa ER-kaavion relaatiomalliin. Toisin sanoen: jos sinulla on valmis ER-kaavio, niin
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 8.3.2016 CSE-A1200 Tietokannat 8.3.2016 1 / 49 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa ER-kaavion relaatiomalliin. Toisin sanoen: jos sinulla on valmis ER-kaavio, niin
CS-A1150 Tietokannat CS-A1150 Tietokannat / 54
CS-A1150 Tietokannat 6.3.2018 CS-A1150 Tietokannat 6.3.2018 1 / 54 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa ER-kaavion relaatiomalliin. Toisin sanoen: jos sinulla on valmis ER-kaavio, niin
CS-A1150 Tietokannat CS-A1150 Tietokannat / 47
CS-A1150 Tietokannat 10.4.2018 CS-A1150 Tietokannat 10.4.2018 1 / 47 Oppimistavoitteet: tämän luennon jälkeen Tiedät, mitä tarkoitetaan hakemistolla ja mitä hyötyä hakemistosta on. Tiedät, miten voidaan
CS-A1150 Tietokannat
CS-A1150 Tietokannat Osa kalvoista perustuu Juha Puustjärven luentokalvoihin aikaisemmalta kurssikerralta sekä kurssin oppikirjaan 30.1.2018 CS-A1150 Tietokannat 30.1.2018 1 / 28 Aloitusluento: tämän luennon
Kyselyt: Lähtökohtana joukko lukuja Laskukaava kertoo miten luvuista lasketaan tulos soveltamalla laskentaoperaatioita
Relaatioalgebra Relaatiomalliin liittyy malli tietokannan käsittelystä Tietokannasta pitää pystyä hakemaan tietoa ja toisaalta tietokantaa on ylläpidettävä Tietokannan käsittelyn malli relaatioalgebra
Relaatioalgebra. Kyselyt:
Relaatioalgebra Relaatiomalliin liittyy malli tietokannan käsittelystä Tietokannasta pitää pystyä hakemaan tietoa ja toisaalta tietokantaa on ylläpidettävä Tietokannan käsittelyn malli relaatioalgebra
Relaatioalgebra. Relaatioalgebra. Relaatioalgebra. Relaatioalgebra - erotus (set difference) Kyselyt:
Relaatiomalliin liittyy malli tietokannan käsittelystä Tietokannasta pitää pystyä hakemaan tietoa ja toisaalta tietokantaa on ylläpidettävä Tietokannan käsittelyn malli relaatioalgebra määrittelee operaatiot,
CS-A1150 Tietokannat CS-A1150 Tietokannat / 43
CS-A1150 Tietokannat 14.3.2017 CS-A1150 Tietokannat 14.3.2017 1 / 43 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa huonon tietokantakaavion paremmaksi: Tiedät mitä tarkoitetaan sillä, että relaatio
SQL:N PERUSTEET MARKKU SUNI
SQL:N PERUSTEET MARKKU SUNI Relaatiomallisen tietokannan käsittely Tietojen saanti, talletus ja päivitys tapahtuu SQL-kielellä Yhtä operaatiota sanotaan kyselyksi (query) Kyselyjä voidaan laittaa peräkkäin
SQL. ! nykystandardi SQL3 eli SQL'99. ! CREATE TABLE, ALTER TABLE ja DROP TABLE. ! CREATE VIEW ja DROP VIEW. ! CREATE INDEX ja DROP INDEX
SQL - perusteet SQL - yleistä Esa Salmikangas InMics SE Oy versio 16.6.2003 SQL - perusteet 1 SQL - perusteet 2 SQL Structured Query Language SQL on tietokantojen käsittelyyn kehitetty kieli yleisimmät
SQL - STRUCTURED QUERY LANGUAGE
SQL Peruskomentoja SQL - STRUCTURED QUERY LANGUAGE SQL on tietokantojen käsittelyyn kehitetty kieli Esimerkkejä kielellä hoidettavistaa toiminnoista: Tietokannan rakenteen määrittely ja muuttaminen Kyselyt
HAAGA-HELIA Heti-09 1 (12) ICT05 Tiedonhallinta ja Tietokannat O.Virkki Näkymät
HAAGA-HELIA Heti-09 1 (12) Näkymät Näkymät... 2 Eri tyyppisiä relaatioita... 2 Taulu - Tallennettu relaatio... 2 Tulosrelaatio - Kyselyn tulos... 2 Näkymä - Virtuaalirelaatio... 2 Näkymien määrittely...
HELIA 1 (14) Outi Virkki Tiedonhallinta
HELIA 1 (14) Luento Näkymät... 2 Relaatiotyypit... 2 Taulu - Tallennettu relaatio... 3 Näkymä - Virtuaalirelaatio... 3 Tulosrelaatio - Kyselyn tulos... 3 Otetaulut - Tauluun tallennettu kyselyn tulos...
CS-A1150 Tietokannat CS-A1150 Tietokannat / 43
CS-A1150 Tietokannat 13.3.2018 CS-A1150 Tietokannat 13.3.2018 1 / 43 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa huonon tietokantakaavion paremmaksi: Tiedät mitä tarkoitetaan sillä, että relaatio
CS-A1150 Tietokannat
CS-A1150 Tietokannat Osa kalvoista perustuu Juha Puustjärven luentokalvoihin aikaisemmalta kurssikerralta sekä kurssin oppikirjaan 4.2.2019 CS-A1150 Tietokannat 4.2.2019 1 / 29 Aloitusluento: tämän luennon
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 12.4.2016 CSE-A1200 Tietokannat 12.4.2016 1 / 42 Oppimistavoitteet: tämän luennon jälkeen Tiedät, mitä tarkoitetaan hakemistolla ja mitä hyötyä hakemistosta on. Tiedät, miten voidaan
Hakukyselyt: SELECT * FROM taulu WHERE sarake1 = Malli Nimi [WHERE sarake1 LIKE M% ] [WHERE BETWEEN ehto1 AND ehto2] [WHERE sarake1 IN/= (alikysely)]
Tällä viikolla Kertaus SQL-asioista jatketaan SQL-tekstifuntio-harjoituksia tehdään pelifirman tietokannasta ER-malli MySQL:llä, tarkastellaan mallin toimivuutta ja korjataan, jos korjattavaa löytyy, tehdään
CS-A1150 Tietokannat CS-A1150 Tietokannat / 51
CS-A1150 Tietokannat 19.3.2019 CS-A1150 Tietokannat 19.3.2019 1 / 51 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa huonon tietokantakaavion paremmaksi: Tiedät mitä tarkoitetaan sillä, että relaatio
TIEDONHALLINTA - SYKSY Luento 8. Saapumisryhmä: Pasi Ranne /9/13 Helsinki Metropolia University of Applied Sciences
TIEDONHALLINTA - SYKSY 2011 Kurssikoodi: Saapumisryhmä: Luento 8 XX00AA79-3013 TU12S2 Pasi Ranne 25.9.2013 25/9/13 Helsinki Metropolia University of Applied Sciences 1 Harjoitustyö Harjoitustöiden tilanne
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 15.3.2016 CSE-A1200 Tietokannat 15.3.2016 1 / 45 Oppimistavoitteet: tämän luennon jälkeen Osaat muuttaa huonon tietokantakaavion paremmaksi: Tiedät mitä tarkoitetaan sillä, että relaatio
Helsingin yliopisto, Tietojenkäsittelytieteen laitos Tietokantojen perusteet, , H.Laine
Helsingin yliopisto, Tietojenkäsittelytieteen laitos Tietokantojen perusteet, 3.5.2007, H.Laine Kirjoita kuhunkin erilliseen vastauspaperiin kurssin nimi, oma nimesi, syntymäaikasi ja nimikirjoituksesi
Esimerkki. pankkien talletus- ja lainatietokanta: Yhdiste, leikkaus, erotus ym. Leikkaus (intersect) Yhdiste (Union) Erotus (except/minus) Leikkaus
Yhdiste, leikkaus, erotus ym. SQL tarjoaa myös relaatioalgebran operaatiot yhdiste, leikkaus, erotus Näissä operaatioissa taulujen on oltava samarakenteisia, ts. niissä on oltava samantyyppiset vastinsarakkeet.
FROM-lausekkeessa voidaan määritellä useampi kuin yksi taulu, josta tietoja haetaan: Tuloksena on taululistassa lueteltujen taulujen rivien
Monen taulun kyselyt FROM-lausekkeessa voidaan määritellä useampi kuin yksi taulu, josta tietoja haetaan: SELECT FROM Tuloksena on taululistassa lueteltujen taulujen rivien karteesinen
HELIA TIKO-05 1 (17) ICT03D Tieto ja tiedon varastointi Räty, Virkki
HELIA TIKO-05 1 (17) SQL / DML 4 Alikyselyt...2 Joukko-operaatiot...7 Yhdiste, unioni...8 Leikkaus...9 Erotus... 10 Tietokannan datan muokkaus... 11 Lisäys... 11 Yhden rivin lisääminen... 12 Useamman rivin
Yhdiste, leikkaus, erotus ym.
Yhdiste, leikkaus, erotus ym. SQL tarjoaa myös relaatioalgebran operaatiot yhdiste, leikkaus, erotus Näissä operaatioissa taulujen on oltava samarakenteisia, ts. niissä on oltava samantyyppiset vastinsarakkeet.
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat Osa kalvoista perustuu Juha Puustjärven luentokalvoihin vuodelta 2011 sekä kurssin oppikirjaan 2.2.2016 CSE-A1200 Tietokannat 2.2.2016 1 / 28 Aloitusluento: tämän luennon jälkeen
7.11.2006. Helsingin yliopisto/tktl Kyselykielet, s 2006 Relaatiokalkyylit. Harri Laine 1
perusteita - relaatiokalkyylit perusteita - relaatiokalkyylit Relaatioalgebra on luonteeltaan proseduraalinen tapa käsitellä tietoa. Tiedon haetaan sarjaksi järjestettyjen operaatioiden avulla. Edellä
CS-A1150 Tietokannat
CS-A1150 Tietokannat Osa kalvoista perustuu Juha Puustjärven luentokalvoihin vuodelta 2011 sekä kurssin oppikirjaan 31.1.2017 CS-A1150 Tietokannat 31.1.2017 1 / 28 Aloitusluento: tämän luennon jälkeen
Helsingin yliopisto/ tktl DO Tietokantojen perusteet, s 2000 Relaatioalgebra 14.9.2000. Harri Laine 1. Relaatioalgebra
DO NOT PRINT THIS DOCUMENT operaatiot, joilla relaatioista voidaan muodostaa uusia relaatioita joukko opin perusoperaatiot yhdiste, erotus, ristitulo, leikkaus erityisiä relaatioalgebran operaatioita projektio,
CS-A1150 Tietokannat CS-A1150 Tietokannat / 43
CS-A1150 Tietokannat 27.2.2018 CS-A1150 Tietokannat 27.2.2018 1 / 43 Oppimistavoitteet: tämän luennon jälkeen Osaat tehdä tietokantaa kuvaavan mallin ER-kaavion avulla. Tunnet esimerkiksi seuraavat ER-mallinnuksen
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat Osa laukaisimia käsittelevistä kalvoista perustuu kurssin oppikirjaan 19.4.2016 CSE-A1200 Tietokannat 19.4.2016 1 / 36 Oppimistavoitteet: tämän luennon jälkeen Osaat määritellä SQL:ssä
2. Haet työntekijöiden tiedot etunimen mukaan nousevasti järjestettyinä. (ORDER BY) SELECT * FROM employees ORDER BY firstname ASC;
Tällä viikolla Kotitehtävien läpikäynti SQL-harjoituksia, osa 1 Jatketaan Pelifirman tietovaraston suunnittelua: tietotyyppien kertaus, taulun luonti ER-kaavioon, taulun luonti kaavion avulla tietokantaan,
Kirjoita jokaiseen erilliseen vastauspaperiin kurssin nimi, tenttipäivä, oma nimesi (selkeästi), opiskelijanumerosi ja nimikirjoituksesi
Helsingin yliopisto, Tietojenkäsittelytieteen laitos Tietokantojen perusteet, kurssikoe 29.2.2012 (vastauksia) Liitteenä on tiivistelmä SQL-syntaksista Kirjoita jokaiseen erilliseen vastauspaperiin kurssin
CS-A1150 Tietokannat
CS-A1150 Tietokannat Osa laukaisimia käsittelevistä kalvoista perustuu kurssin oppikirjaan 29.4.2019 CS-A1150 Tietokannat 29.4.2019 1 / 39 Oppimistavoitteet: tämän luennon jälkeen Osaat määritellä SQL:ssä
Tietokannat II -kurssin harjoitustyö
Tietokannat II -kurssin harjoitustyö Jyri Lehtonen (72039), jkoleh@utu.fi Azad Hajipour (72187), azhaji@utu.fi 10.6.2007 Sisältö 1. Tietokannan kuvaus... 1 1.1 Tietokannan rakenne... 1 1.2 Relaatiokaava
joukko operaatioita, joilla relaatioista voidaan muodostaa uusia relaatioita joukko opin perusoperaatiot yhdiste, erotus, ristitulo, leikkaus
DO NOT PRINT THIS DOCUMENT joukko operaatioita, joilla relaatioista voidaan muodostaa uusia relaatioita joukko opin perusoperaatiot yhdiste, erotus, ristitulo, leikkaus erityisiä relaatioalgebran operaatioita
Helsingin yliopisto/ tktl D Tietokantojen perusteet, s 2000 Relaatioalgebra. Harri Laine 1. Relaatioalgebra.
Tietokantaoperaatiot tiedon haku kyselyt miten märitellään haettava tieto ylläpito-operaatiot lisäys, poisto, muuttaminen Kyselyt: lähtökohtana tietokannan tila joukkona relaatioita kyselyn tuloksena yksi
Liitokset - haut useaan tauluun
Liitokset Liitokset - haut useaan tauluun Tavallisin liitos on valintaliitos ehtona =,!=, yhtäläisyysliitos (=) yleisin (vrt. Inner join) taulut liitetään toisiinsa yleensä avaimilla (perus-
CSE-A1200 Tietokannat
CSE-A1200 Tietokannat 1.3.2016 CSE-A1200 Tietokannat 1.3.2016 1 / 41 Oppimistavoitteet: tämän luennon jälkeen Osaat tehdä tietokantaa kuvaavan mallin ER-kaavion avulla. Tunnet esimerkiksi seuraavat ER-mallinnuksen
Insert lauseella on kaksi muotoa: insert into taulu [(sarakenimet)] values (arvot)
SQL sisältää operaatiot tietokannan sisällön muodostamiseen ja ylläpitoon: insert - uusien rivien vienti tauluun delete - rivien poisto update - rivien muutos 1 Insert lauseella on kaksi muotoa: insert
TIEDONHALLINTA - SYKSY Luento 11. Hannu Markkanen /10/12 Helsinki Metropolia University of Applied Sciences
TIEDONHALLINTA - SYKSY 2011 Kurssikoodi: Saapumisryhmä: Luento 11 TU00AA48-2002 TU10S1E Hannu Markkanen 22.11.2011 9/10/12 Helsinki Metropolia University of Applied Sciences 1 Indeksit Indeksit Taulun
Helsingin yliopisto Tietojenkäsittelytieteen laitos (H.Laine) Tietokantojen perusteet. Liitteenä: Tiivistelmä SQL-syntaksista
Helsingin yliopisto Tietojenkäsittelytieteen laitos 26.2.2014 (H.Laine) Tietokantojen perusteet Liitteenä: Tiivistelmä SQL-syntaksista Kirjoita jokaiseen erilliseen vastausarkkiin kurssin nimi, tenttipäivä,
Tietokantojen suunnittelu, relaatiokantojen perusteita
Tietokantojen suunnittelu, relaatiokantojen perusteita A277, Tietokannat Teemu Saarelainen teemu.saarelainen@kyamk.fi Lähteet: Leon Atkinson: core MySQL Ari Hovi: SQL-opas TTY:n tietokantojen perusteet-kurssin
Relaation tyhjyyden testaaminen
Tulostaulun tyhjyyden testaaminen Luettele ne asiakkaat, joilla on sekä talletus että laina -konttorissa. (Leikkaus!) useita mahdollisia toteutustapoja INTERSECT sisäkysely sisäkysely + tulostaulun tyhjyyden
HAAGA-HELIA TIKO-05 1 (19) ICT23a Tietokannan suunnittelu ja toteutus O.Virkki 4.9.2008
HAAGA-HELIA TIKO-05 1 (19) Relaatiomalli Relaatiomalli... 2 Peruskäsitteet... 3 Relaatio... 5 Attribuutti ja arvojoukko... 6 Monikko... 7 Säännöt... 8 Yksilön eheyssääntö ja Pääavain... 9 Viite-eheyssääntö
Tiedonhallinnan perusteet. Viikko 1 Jukka Lähetkangas
Tiedonhallinnan perusteet Viikko 1 Jukka Lähetkangas Kurssilla käytävät asiat Tietokantojen toimintafilosofian ja -tekniikan perusteet Tiedonsäilönnän vaihtoehdot Tietokantojen suunnitteleminen internetiä
HELIA 1 (17) Outi Virkki Tiedonhallinta
HELIA 1 (17) Luento 4.1 Looginen suunnittelu... 2 Relaatiomalli... 3 Peruskäsitteet... 4 Relaatio... 6 Relaatiokaava (Relation schema)... 6 Attribuutti ja arvojoukko... 7 Monikko... 8 Avaimet... 10 Avain
Tietokantojen perusteet, syksy 1999 SQL- osa Harri Laine 1. SQL-valintaehto. SQL-valintaehto. Opettajien nimet: Opiskelijoiden pääaineet
DO NOT PRINT THIS DOCUMENT SQL -valintaehto CREATE TABLE opettaja ( opetunnus varchar(12) NOT NULL, nimi varchar(40) NOT NULL, puhelin varchar(12), tyohuone varchar(12), PRIMARY KEY (opetunnus) ) ; CREATE
Relaatiomalli ja -tietokanta
Relaatiomalli ja -tietokanta > Edgar. F. (Ted) Codd, IBM, 1969 < A Relational Model of Data for Large Shared Data Banks Communications of the ACM, Vol. 13, No. 6, June 1970, pp. 377-387. > 70-luvun lopulla
Tietokannan hallinta. Kevät 2004 Jan Lindström R&G Chapter 1
Tietokannan hallinta Kevät 2004 Jan Lindström R&G Chapter 1 Tietokannan hallinta 1. Johdanto (käsitteitä) 2. Tietokannan talletusrakenteet 3. Tietokannan hakemistorakenteet 4. Kyselyiden käsittely ja optimointi
HELIA TIKO-05 1 (15) ICT03D Tieto ja tiedon varastointi Räty, Virkki 25.10.2006
HELIA TIKO-05 1 (15) SQL / DML 3 Liitos...2 SQL-92:n join operaatio...4 SQL-89:n join operaatio:...5 Karteesinen tulo... 10 Ulkoliitos (Outer join)... 11 Vasemmanpuoleinen ulkoliitos... 12 Oikeanpuoleinen
Helsingin yliopisto, TKTL Tietokantojen perusteet, k 2000 SQL- osa Harri Laine 1. SQL-valintaehto. SQL-valintaehto.
DO NOT PRINTTHIS DOCUMENT SQL -valintaehto SQL-valintaehto CREATE TABLE opettaja ( opetunnus varchar(12) NOT NULL, nimi varchar(40) NOT NULL, puhelin varchar(12), tyohuone varchar(12), PRIMARY KEY (opetunnus)
Tietokannat. CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi);
Tietokannat SQL-peruskomentojen pikaopas CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi); INSERT INTO table VALUES(val1,val2,... ); Lisää tauluun
Tietokannat. CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi);
Tietokannat SQL-peruskomentojen pikaopas CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi); INSERT INTO table VALUES(val1,val2,... ); Lisää tauluun
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 16.2.2010 T-106.1208 Ohjelmoinnin perusteet Y 16.2.2010 1 / 41 Kännykkäpalautetteen antajia kaivataan edelleen! Ilmoittaudu mukaan lähettämällä ilmainen tekstiviesti
SQL:N PERUSTEET MARKKU SUNI
SQL:N PERUSTEET MARKKU SUNI Vertailuoperaattorit Vertailuoperaattorit vertailevat lausekkeiden arvoja Vertailu palauttaa jonkin kolmesta arvosta: TRUE Tosi FALSE Falski, väärä NULL Tuntematon JOS vertailuehtona
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 25.2.2009 T-106.1208 Ohjelmoinnin perusteet Y 25.2.2009 1 / 34 Syötteessä useita lukuja samalla rivillä Seuraavassa esimerkissä käyttäjä antaa useita lukuja samalla
Kyselyn yleisrakenne:
SQL kysely Kyselyn yleisrakenne: select tulostietomäärittely from taulukkeet [where valintaehdot] [group by ryhmitystekijät] [having ryhmärajoitteet] [order by järjestysperusta] Kysely tuottaa nimettömän
Harjoitustyö. CSE-A1200 Tietokannat! Jasse Lahdenperä! 345396! killedwhale@kapsi.fi! Henri Nurmi! 345545! henri.nurmi@kapsi.fi!
Harjoitustyö CSE-A1200 Tietokannat Jasse Lahdenperä 345396 killedwhale@kapsi.fi Henri Nurmi 345545 henri.nurmi@kapsi.fi 1 Ensimmäisen vaiheen ratkaisu ER-Kaavio 2 Relaatiomalli: Loanable(Id, MaximumLoanTime)
Kuva 7.2 vastaustaulu harjoitukseen 7.2
Harjoitus 7. Lataa tiedosto http://users.metropolia.fi/~pasitr/opas/ran13b/data/ran13b.zip levylle Z: ja pura se. Kun olet tehnyt kaikki seuraavat 17 tehtävää palauta Tuubiin harjoituksen 7 vastauksena
Tällä viikolla. Kotitehtävien tarkistus Upotettu SQL Indeksi-harjoitus täydennetään pelifirman tietokantamallia SQL-tehtäviä
Tällä viikolla Kotitehtävien tarkistus Upotettu SQL Indeksi-harjoitus täydennetään pelifirman tietokantamallia SQL-tehtäviä Seuraavissa harjoituksissa käytetään tukkukauppa-kantaa. 1. Hae kaikki toimittajat
Relaatiotietokantojen perusteista. Harri Laine Helsingin yliopisto
Harri Laine Helsingin yliopisto Suosion syy? Yksinkertaisuus vähän käsitteitä helppo hahmottaa Selkeä matemaattinen perusta ei tulkintaongelmia kuten esim. UML:ssä teoria käytäntö kaavio: R(A 1 :D 1, A
Opettajana Mika Sorsa, mika.sorsa@koudata.fi, HAMK:n ammatillisen opettajakoulutuksen opetusharjoittelija
Opettajana Mika Sorsa, mika.sorsa@koudata.fi, HAMK:n ammatillisen opettajakoulutuksen opetusharjoittelija Opintojaksolla: keskitytään relaatiotietokantojen teoriaan ja toimintaan SQL-kieli kyselykielenä
Tällä viikolla. Kotitehtävien läpikäynti Aloitetaan Pelifirman tietovaraston suunnittelu Jatketaan SQL-harjoituksia
Tällä viikolla Kotitehtävien läpikäynti Aloitetaan Pelifirman tietovaraston suunnittelu Jatketaan SQL-harjoituksia 1.) Mainitse tietokonepelistä (kuvitteellisesta tai todellisesta) esimerkkitilanteita,
TIETOKANTOJEN PERUSTEET MARKKU SUNI
TIETOKANTOJEN PERUSTEET MARKKU SUNI SQL - KIELI TIETOJEN MUOKKAUS MARKKU SUNI Tarkastellaan tauluissa olevien tietojen muokkausta muokkauskäskyjä: INSERT UPDATE DELETE Kysymys kuuluu: Voiko tietoja muokata
TIEDONHALLINNAN PERUSTEET - SYKSY 2013
TIEDONHALLINNAN PERUSTEET - SYKSY 2013 Kurssikoodi: Saapumisryhmä: Luento 5 XX00AA79-3013 TU12S2 Pasi Ranne 11.9.2013 11/9/13 Helsinki Metropolia University of Applied Sciences 1 Tietokannan normalisoinnin
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 17.2.2010 T-106.1208 Ohjelmoinnin perusteet Y 17.2.2010 1 / 41 Sanakirja Monissa sovelluksissa on tallennettava rakenteeseen avain arvo-pareja. Myöhemmin rakenteesta
TIETOKANNAT JOHDANTO
TIETOKANNAT JOHDANTO JOUNI HUOTARI & ARI HOVI 2000-2011 Tieto TAUSTAA Yritykselle tiedot ovat tärkeä resurssi päätöksenteon tukena (JIT) varastointi ja käyttö vaativat investointeja vrt. energia (lähde,
Kirjoita kuhunkin erilliseen vastauspaperiin kurssin nimi, tentin päiväys, oma nimesi, syntymäaikasi ja nimikirjoituksesi.
Helsingin yliopisto, Tietojenkäsittelytieteen laitos Tietokantojen perusteet, kurssikoe 4.3.2015, H. Laine Tehtävien mukana jaetaan sql-syntaksin tiivistelmä. Kirjoita kuhunkin erilliseen vastauspaperiin
TIETOKANNAT: MYSQL & POSTGRESQL Seminaarityö
TIETOKANNAT: MYSQL & POSTGRESQL Seminaarityö Tekijät: Eemeli Honkonen Joni Metsälä Työ palautettu: SISÄLLYSLUETTELO: 1 SEMINAARITYÖN KUVAUS... 3 2 TIETOKANTA... 3 2.1 MITÄ TIETOKANNAT SITTEN OVAT?... 3
Java-kielen perusteet
Java-kielen perusteet Tunnus, varattu sana, kommentti Muuttuja, alkeistietotyyppi, merkkijono, Vakio Tiedon merkkipohjainen tulostaminen Ohjelmointi (ict1tx006) Tunnus (5.3) Javan tunnus Java-kirjain Java-numero
Java-kielen perusteet
Java-kielen perusteet Tunnus, varattu sana, kommentti Muuttuja, alkeistietotyyppi, merkkijono, literaalivakio, nimetty vakio Tiedon merkkipohjainen tulostaminen 1 Tunnus Java tunnus Java-kirjain Java-numero
Jokaisella tiedostolla on otsake (header), joka sisältää tiedostoon liittyvää hallintatietoa
Tietojen tallennusrakenteet Jokaisella tiedostolla on otsake (header), joka sisältää tiedostoon liittyvää hallintatietoa tiedot tiedostoon kuuluvista lohkoista esim. taulukkona, joka voi muodostua ketjutetuista
HELIA 1 (14) Outi Virkki Tiedonhallinta
HELIA 1 (14) Luento SQL... 2 Historiaa... 2 Standardit... 3 Käyttö... 4 DDL... 5 Tietokantaobjektien määrittely... 5 SQL:n tietotyypit... 6 Eheyssääntöjen määrittely... 9 Indeksin määrittely... 11 Syntaksikuvaukset...
HAAGA-HELIA heti09 1 (27) ICT05 Tiedonhallinta ja tietokannat O.Virkki 19.1.2010. Relaatiomalli
HAAGA-HELIA heti09 1 (27) Relaatiomalli Relaatiomalli... 2 Peruskäsitteet... 3 Relaatio... 5 Attribuutti ja arvojoukko... 6 Monikko... 7 Säännöt... 8 Arvojoukkoeheyssääntö... 8 Pääavain ja yksilön eheyssääntö...
HELIA 1 (11) Outi Virkki Tiedonhallinta 4.11.2000
HELIA 1 (11) Access 1 ACCESS...2 Yleistä...2 Access-tietokanta...3 Perusobjektit...3 Taulu...5 Kysely...7 Lomake...9 Raportti...10 Makro...11 Moduli...11 HELIA 2 (11) ACCESS Yleistä Relaatiotietokantatyyppinen
Tietokannat. CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi);
Tietokannat SQL-peruskomentojen pikaopas CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi); INSERT INTO table VALUES(val1,val2,... ); Lisää tauluun
Alkuarvot ja tyyppimuunnokset (1/5) Alkuarvot ja tyyppimuunnokset (2/5) Alkuarvot ja tyyppimuunnokset (3/5)
Alkuarvot ja tyyppimuunnokset (1/5) Aiemmin olemme jo antaneet muuttujille alkuarvoja, esimerkiksi: int luku = 123; Alkuarvon on oltava muuttujan tietotyypin mukainen, esimerkiksi int-muuttujilla kokonaisluku,
OpenOffice.org Base 3.1.0
OpenOffice.org Base 3.1.0 Sisällysluettelo 1 Tietokannan luominen...1 2 Taulukon eli taulun luominen...3 3 Kysely...9 4 Raportti...14 1 Tietokannan luominen Tietokanta on kokoelma tietoja, joilla on yhteys
HELIA 1 (15) Outi Virkki Tietokantasuunnittelu 13.11.2000
HELIA 1 (15) Luento 2.7 Toiminnallisuutta tietokantaan... 2 Deklaratiivinen eheysvalvonta... 2 Proseduraalinen eheysvalvonta... 3 Eheysvalvonnan suunnittelusta... 4 Sääntöjen määrittely... 4 Toteutusvaihtoehdot...
Harjoitustehtävä 1. Harjoitustehtävän 1 ratkaisu. Harjoitustehtävä 1. Relaatioalgebra -liitokset (join) Liitos
Harjoitustehtävän 1 ratkaisu Tonttu( tonttutunnus, nimi) Puutarha( puutarhatunnus, omistaja, sijainti ) Vastuualue ( puutarhatunnus->puutarha, aluenumero, maaperä, kosteus, valaistus, sijainti, vastuutonttu
17 BUDJETOINTI. Asiakaskohtainen Budjetti. 17.1 Ylläpito-ohjelma. Dafo Versio 10 BUDJETOINTI. Käyttöohje. BudgCust. 17.1.1 Yleistä
17 Asiakaskohtainen Budjetti 17.1 Ylläpito-ohjelma 17.1.1 Yleistä BudgCust Ohjelmalla avataan järjestelmään asiakaskohtaisia budjetteja, jotka annetaan kuukausitasolla (oletus). 17.1.2 Parametrit Ohjelmaa