SQL:N PERUSTEET MARKKU SUNI



Samankaltaiset tiedostot
TIETOKANTOJEN PERUSTEET MARKKU SUNI

SQL:N PERUSTEET MARKKU SUNI

SELECT-lauseen perusmuoto

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

SQL - STRUCTURED QUERY LANGUAGE

TIEDONHALLINTA - SYKSY Luento 8. Saapumisryhmä: Pasi Ranne /9/13 Helsinki Metropolia University of Applied Sciences

HAAGA-HELIA Heti-09 1 (12) ICT05 Tiedonhallinta ja Tietokannat O.Virkki Näkymät

Tällä viikolla. Kotitehtävien tarkistus Upotettu SQL Indeksi-harjoitus täydennetään pelifirman tietokantamallia SQL-tehtäviä

SQL. ! nykystandardi SQL3 eli SQL'99. ! CREATE TABLE, ALTER TABLE ja DROP TABLE. ! CREATE VIEW ja DROP VIEW. ! CREATE INDEX ja DROP INDEX

Kyselyn yleisrakenne:

CSE-A1200 Tietokannat

Kuva 7.2 vastaustaulu harjoitukseen 7.2

HELIA 1 (14) Outi Virkki Tiedonhallinta

TIEDONHALLINTA - SYKSY Luento 11. Hannu Markkanen /10/12 Helsinki Metropolia University of Applied Sciences

FROM-lausekkeessa voidaan määritellä useampi kuin yksi taulu, josta tietoja haetaan: Tuloksena on taululistassa lueteltujen taulujen rivien

HELIA 1 (11) Outi Virkki Tiedonhallinta

TIETOKANTOJEN PERUSTEET MARKKU SUNI

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

Relaation tyhjyyden testaaminen

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

Tietokannat. CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi);

TIEDONHALLINTA - SYKSY Luento 10. Hannu Markkanen /10/12 Helsinki Metropolia University of Applied Sciences

VINKKI: Katso Kentät Muistioon -painikkeella, mikä on taulukon nimen oikea kirjoitusasu.

CS-A1150 Tietokannat CS-A1150 Tietokannat / 39

HELIA TIKO-05 1 (17) ICT03D Tieto ja tiedon varastointi Räty, Virkki

select tulostietomäärittely from taulukkeet [where valintaehdot] [group by ryhmitystekijät] [having ryhmärajoitteet] [order by järjestysperusta]

Hakukyselyt: SELECT * FROM taulu WHERE sarake1 = Malli Nimi [WHERE sarake1 LIKE M% ] [WHERE BETWEEN ehto1 AND ehto2] [WHERE sarake1 IN/= (alikysely)]

CSE-A1200 Tietokannat

KAAVAT. Sisällysluettelo

Tietokannat. CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi);

17 BUDJETOINTI. Asiakaskohtainen Budjetti Ylläpito-ohjelma. Dafo Versio 10 BUDJETOINTI. Käyttöohje. BudgCust Yleistä

Matriisit, L20. Laskutoimitukset. Matriisikaavoja. Aiheet. Määritelmiä ja merkintöjä. Laskutoimitukset. Matriisikaavoja. Matriisin transpoosi

3. Muuttujat ja operaatiot 3.1

Excel 2016 Power Pivot

Yhdiste, leikkaus, erotus ym.

SYÖTTÖPOHJA LUKUJEN SYÖTTÖÖN ERI TARKOITUKSIIN

Helsingin yliopisto, Tietojenkäsittelytieteen laitos Tietokantojen perusteet, , H.Laine

13. Loogiset operaatiot 13.1

Tällä viikolla. Kotitehtävien läpikäynti Aloitetaan Pelifirman tietovaraston suunnittelu Jatketaan SQL-harjoituksia

Johdanto Javaan ja tietokantojen käsittelyyn Java Database Connectivity (JDBC)

Liitokset - haut useaan tauluun

Opettajana Mika Sorsa, HAMK:n ammatillisen opettajakoulutuksen opetusharjoittelija

Sisällys. 3. Muuttujat ja operaatiot. Muuttujat ja operaatiot. Muuttujat. Operaatiot. Imperatiivinen laskenta. Muuttujat. Esimerkkejä: Operaattorit.

TIETOKANTOJEN PERUSTEET OSIO 14 MARKKU SUNI

Johdatus Ohjelmointiin

Helsingin yliopisto Tietojenkäsittelytieteen laitos (H.Laine) Tietokantojen perusteet. Liitteenä: Tiivistelmä SQL-syntaksista

Java-kielen perusteet

Java-kielen perusteet

HELIA TIKO-05 1 (15) ICT03D Tieto ja tiedon varastointi Räty, Virkki

Esimerkki. pankkien talletus- ja lainatietokanta: Yhdiste, leikkaus, erotus ym. Leikkaus (intersect) Yhdiste (Union) Erotus (except/minus) Leikkaus

Matriisit, L20. Laskutoimitukset. Matriisikaavoja. Aiheet. Määritelmiä ja merkintöjä. Laskutoimitukset. Matriisikaavoja. Matriisin transpoosi

Tietokantojen perusteet, syksy 1999 SQL- osa Harri Laine 1. SQL-valintaehto. SQL-valintaehto. Opettajien nimet: Opiskelijoiden pääaineet

Vain valitut kentät: SELECT Päivämäärä, Laskutusnimi, [ale mk], Loppusumma FROM Laskuotsikot

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

Ohjelmoinnin perusteet Y Python

2. Haet työntekijöiden tiedot etunimen mukaan nousevasti järjestettyinä. (ORDER BY) SELECT * FROM employees ORDER BY firstname ASC;

Täydentäviä muistiinpanoja kontekstittomien kielioppien jäsentämisestä

Excel PowerPivot

Helsingin yliopisto/tktl Kyselykielet, s 2006 Relaatiokalkyylit. Harri Laine 1

Koostefunktiot. Viisi standardifunktiota: Esim. montako henkilöä on henkilo-taulussa:

HELIA SQL-harjoituksia 1(1) atk72d Versiopvm:

OUTER JOIN se vanha kunnon kaveri

Ohjelmoinnin perusteet Y Python

Joko tunnet nämän Oracle10g SQL:n piirteet? Kari Aalto Saariston IT

ASTERI-OHJELMIEN SQL-ERIKOISKURSSI LUENTOKALVOT

Matriisit, kertausta. Laskutoimitukset. Matriisikaavoja. Aiheet. Määritelmiä ja merkintöjä. Laskutoimitukset. Matriisikaavoja. Matriisin transpoosi

Helsingin yliopisto, TKTL Tietokantojen perusteet, k 2000 SQL- osa Harri Laine 1. SQL-valintaehto. SQL-valintaehto.

Harjoitus 5. Esimerkki ohjelman toiminnasta: Lausekielinen ohjelmointi I Kesä 2018 Avoin yliopisto 1 / 5

Tietokantojen perusteet, syksy 1999 SQL- osa Harri Laine 1. SQL-yhteenvetofunktiot. SQL-yhteenvetofunktiot

Excel 2010 ja QlikView. Mihin ja milloin pivot:ia voi käyttää

13. Loogiset operaatiot 13.1

Helsingin yliopisto, tktl DO Tietokantojen perusteet, kevät 2000 SQL- osa Harri Laine 1. SQL-yhteenvetofunktiot. SQL-yhteenvetofunktiot

Tietokannat II -kurssin harjoitustyö

Excel syventävät harjoitukset

Ehto- ja toistolauseet

Harjoitus 5 (viikko 41)

Kurssin loppuosassa tutustutaan matriiseihin ja niiden käyttöön yhtälöryhmien ratkaisemisessa.

HELIA TIKO-05 1 (22) ICT03D Tieto ja tiedon varastointi E.Räty, O.Virkki

Tietokannat. CREATE TABLE table(col1,col2,... ); Luo uuden taulun. CREATE TABLE opiskelijat(opnumero,etunimi,sukunimi);

n! k!(n k)! n = Binomikerroin voidaan laskea pelkästään yhteenlaskun avulla käyttäen allaolevia ns. palautuskaavoja.

Algoritmit. Ohjelman tekemisen hahmottamisessa käytetään

LIIKEMATKATOIMISTOJÄRJESTELMÄN OHJE

Kirjoita kuhunkin erilliseen vastauspaperiin kurssin nimi, tentin päiväys, oma nimesi, syntymäaikasi ja nimikirjoituksesi.

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

Tiedonhallinnan perusteet. Viikko 1 Jukka Lähetkangas

Ohjelmoinnin perusteet Y Python

Proseduurit, funktiot ja herättimet - esimerkkeinä Oracle, SQL Server, MySQL ja OCELOT. Jouni Huotari S2008

PERUSLASKUJA. Kirjoita muuten sama, mutta ota KAKSI välilyöntiä (SEURAA ALUEMERKINTÄÄ) 4:n jälkeen 3/4 +5^2

PROSEDUURIT, FUNKTIOT JA HERÄTTIMET - ESIMERKKEINÄ ORACLE, SQL SERVER, MYSQL JA OCELOT JOUNI HUOTARI K2009

Luento 7 Taulukkolaskennan edistyneempiä piirteitä Aulikki Hyrskykari

TIEDONHALLINNAN PERUSTEET - SYKSY 2013

Alkuarvot ja tyyppimuunnokset (1/5) Alkuarvot ja tyyppimuunnokset (2/5) Alkuarvot ja tyyppimuunnokset (3/5)

CLT131 Korpusten käsittely

Kaulaketju. Syöte. Tuloste. Esimerkki 1. Esimerkki 2

HELIA 1 (11) Outi Virkki Tiedonhallinta

RADAR - RANDOM DATA GENERATOR

TIETOKANTOJEN PERUSTEET OSIO 11 MARKKU SUNI

Helsingin yliopisto, tktl DO Tietokantojen perusteet, kevät 2000 SQL- osa Harri Laine 1. SQL-yhteenvetofunktiot. SQL-yhteenvetofunktiot

Tarina-tehtävän ratkaisu

MUITA TIETOKANTAOBJEKTEJA NÄKYMÄT, SYNONYYMIT, INDEKSOINTI, VALTUUDET JA SYSTEEMIHAKEMISTO

Transkriptio:

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-kieli on varsin hyvin standardoitu On toimittajakohtaisia poikkeuksia SQL-kyselyn saa sijoitella riveille vapaasti Isot ja pienet kirjaimet ovat samanarvoisia Listat tunnistetaan siitä, että pilkku erottaa jäsenet

Katsotaanpa hiukan SQLkieltä

Peruskyselyn malli SQL:llä CREATE TABLE tulos AS SELECT henkilonro, nimi,, osoite, tilisaldo FROM henkilot, tilit WHERE henkilot.henkilonro = tilit.henkilonro AND tilisaldo > 100 ORDER BY nimi ;

Peruskyselyn malli SQL:llä CREATE TABLE tulos AS CREATE mitä syntyy tuloksena uusi taulu näkymä indeksi SELECT henkilonro, nimi, osoite, tilisaldo FROM henkilot, tilit WHERE henkilot.henkilonro = tilit.henkilonro AND tilisaldo > 100 ORDER BY nimi ;

Peruskyselyn malli SQL:llä CREATE TABLE tulos AS SELECT henkilonro, nimi, osoite, tilisaldo SELECT mitä (sarakkeita) halutaan tulokseen lausekkeet erotetaan pilkuilla toisistaan tauluissa jo olevia sarakkeiden perusteella laskettuja tms. muodostettuja kokonaan tyhjästä muodostettuja miten niitä nimitetään FROM henkilot, tilit WHERE henkilot.henkilonro = tilit.henkilonro AND tilisaldo > 100 ORDER BY nimi ;

Peruskyselyn malli SQL:llä CREATE TABLE tulos AS SELECT henkilonro, nimi, osoite, tilisaldo FROM henkilot, tilit FROM - mistä tauluista sarakkeita poimitaan yksi tai useita taulut erotetaan pilkuilla toisistaan mahdollisesti käytetään alias-nimiä WHERE henkilot.henkilonro = tilit.henkilonro AND tilisaldo > 100 ORDER BY nimi ;

Peruskyselyn malli SQL:llä CREATE TABLE tulos AS SELECT henkilonro, nimi, osoite, tilisaldo FROM henkilot, tilit WHERE henkilot.henkilonro = tilit.henkilonro AND tilisaldo > 100 WHERE ehdot, jotka täyttävät sarakkeet halutaan liittyvät taulujen sarakkeiden arvoihin voi olla hyvinkin monimutkaisia ehtoja voi olla sisäkkäisiä kyselyjä ehtoina ORDER BY nimi ;

Peruskyselyn malli SQL:llä CREATE TABLE tulos AS SELECT henkilonro, nimi, osoite, tilisaldo FROM henkilot, tilit WHERE henkilot.henkilonro = tilit.henkilonro AND tilisaldo > 100 ORDER BY nimi ; ORDER BY, GROUP BY miten tulos esitetään lajiteltuna, ryhmiteltynä mahdollisesti tehdään summia tms. ryhmittelyn mukaan

LAUSEKE on nimien ja operaattorien yhdistelmä, joka palauttaa arvon OPERAATTORI on esim. + - * / EHTO on lauseke,joka saa arvon tosi tai väärä EHTO on tapa rajoittaa valittavia rivejä EHTO on esim.: nimi = SUNI paino > 50 veropros > 40

SQL-kyselyn palauttamien rivien määrää rajoitetaan WHERE-ehdolla WHERE <ehtolauseke> Mukaan tulevat vain ehdon täyttävät rivit

SELECT * FROM tilaukset WHERE tilaustunnus = 10249; ja tuloksena tulee Tilaustunnus Asiakas Työntekijän nimi Tilauspäivämäärä 10249 Toms Spezialitäten Suyama, Michael 05-07-1996

Aritmeettiset operaattorit: + yhteenlasku - vähennyslasku * kertolasku / jakolasku ( ) sulut

Aritmeettiset operaattorit: yhteenlasku SELECT tilaustunnus, rahti, rahti+12 from tilaukset; Tilaustunnus rahti Expr1002 10248 145,71 mk 157,71 mk 10249 52,25 mk 64,25 mk 10250 296,24 mk 308,24 mk 10251 186,03 mk 198,03 mk 10252 230,85 mk 242,85 mk 10253 261,77 mk 273,77 mk 10254 103,41 mk 115,41 mk

Aritmeettiset operaattorit: yhteenlasku SELECT tilaustunnus, rahti, rahti+12 AS Mukana vero from tilaukset; Tilaustunnus rahti Mukana vero 10248 145,71 mk 157,71 mk 10249 52,25 mk 64,25 mk 10250 296,24 mk 308,24 mk 10251 186,03 mk 198,03 mk 10252 230,85 mk 242,85 mk 10253 261,77 mk 273,77 mk 10254 103,41 mk 115,41 mk

Aritmeettiset operaattorit: yhteenlasku SELECT tilaustunnus, rahti, ( rahti+12 ) AS Mukana vero from tilaukset; Tilaustunnus rahti Mukana vero 10248 145,71 mk 157,71 mk 10249 52,25 mk 64,25 mk 10250 296,24 mk 308,24 mk 10251 186,03 mk 198,03 mk 10252 230,85 mk 242,85 mk 10253 261,77 mk 273,77 mk 10254 103,41 mk 115,41 mk Joissakin järjestelmissä voi AS-sanan jättää pois

Aritmeettiset operaattorit: yhteenlasku SELECT tilaustunnus, -rahti, ( rahti+12 ) AS Mukana vero from tilaukset; Tilaustunnus Expr1001 Mukana vero 10248-145,71 mk 157,71 mk 10249-52,25 mk 64,25 mk 10250-296,24 mk 308,24 mk 10251-186,03 mk 198,03 mk 10252-230,85 mk 242,85 mk 10253-261,77 mk 273,77 mk 10254-103,41 mk 115,41 mk Joissakin järjestelmissä voi AS-sanan jättää pois

Aritmeettiset operaattorit: miinusmerkki SELECT tilaustunnus, -rahti AS negatiivinen, ( rahti+12 ) AS Mukana vero from tilaukset; Tilaustunnus negatiivinen Mukana vero 10248-145,71 mk 157,71 mk 10249-52,25 mk 64,25 mk 10250-296,24 mk 308,24 mk 10251-186,03 mk 198,03 mk 10252-230,85 mk 242,85 mk 10253-261,77 mk 273,77 mk 10254-103,41 mk 115,41 mk

SQL-kielen jotkin toteutukset hyväksyvät SELECT tilaustunnus, -rahti AS negatiivinen, rahti+12 AS Mukana vero FROM tilaukset; SELECT tilaustunnus, -rahti = negatiivinen, rahti+12 = Mukana vero FROM tilaukset; Aliasnimi SELECT tilaustunnus, -rahti negatiivinen, rahti+12 Mukana vero FROM tilaukset;

Aritmeettiset operaattorit SELECT tilaustunnus, rahti-15 AS veroton, ( rahti+12 ) AS Tullimukana from tilaukset; Tilaustunnus veroton Tullimukana 10248 130,71 mk 157,71 mk 10249 37,25 mk 64,25 mk 10250 281,24 mk 308,24 mk 10251 171,03 mk 198,03 mk 10252 215,85 mk 242,85 mk 10253 246,77 mk 273,77 mk 10254 88,41 mk 115,41 mk

Lasketaan, kun kerran ruvettiin SELECT tilaustunnus, rahti*1.22 AS Verollinen, ( rahti*1.22*0.85 ) AS Alennettu from tilaukset; Tilaustunnus Verollinen Alennettu 10248 177,7662 151,10127 10249 63,7389 54,17806 10250 361,4067 307,195695 10251 226,9566 192,91311 10252 281,637 239,39145 10253 319,3533 271,450305 10254 126,1602 107,23617

Lasketaan, kun kerran ruvettiin SELECT tilaustunnus, rahti*1.22 AS Verollinen, ( rahti*1.22*0.85 ) AS Alennettu from tilaukset WHERE rahti > 200; Tilaustunnus Verollinen Alennettu 10250 361,4067 307,195695 10252 281,637 239,39145 10253 319,3533 271,450305 10255 814,3317 692,181945 10257 449,6859 382,233015 10258 771,3999 655,689915 10260 302,4441 257,077485 10262 265,1121 225,345285 10263 801,8694 681,58899

CREATE TABLE SELECT tulos AS yritys, osoite, postinumero, toimituspäivämäärä, rahti FROM asiakkaat, tilaukset WHERE rahti > 500 ORDER BY yritys ;

Yritys osoite Postinumero Toimituspäivämäärä rahti Richter Supermarkt Grenzacherweg 71203 09-08-1996 667,49 mk Ernst Handel Kirchgasse 68010 14-08-1996 632,30 mk Ernst Handel Kirchgasse 68010 20-08-1996 657,27 mk Frankenversand Berliner Platz43808 26-08-1996 938,61 mk Wartian Herkku Torikatu 38901 29-08-1996 614,43 mk Morgenstern Gesund Heerstr. 22041 06-09-1996 565,97 mk QUICK-Stop Taucherstraße 10013 18-09-1996 1 031,58 mk Rattlesnake Grocery Milton Dr. 87110 27-09-1996 662,67 mk.......

CREATE TABLE SELECT tulos AS yritys, osoite, postinumero, toimituspäivämäärä, rahti FROM asiakkaat a, tilaukset t WHERE a.asiakastunnus = t.asiakastunnus AND rahti > 500 ORDER BY yritys ;

Yritys osoite Postinumero Toimituspäivämäärä rahti Around the Horn120 Hanover Sq.WA1 1DP 05-01-1998 658,44 mk Berglunds snabbköp Berguvsvägen 8S-958 01-04-1998 681,84 mk Berglunds snabbköp Berguvsvägen 8S-958 01-04-1998 681,84 mk Berglunds snabbköp Berguvsvägen 8S-958 29-05-1997 1 101,56 mk Berglunds snabbköp Berguvsvägen 8S-958 25-02-1998 849,83 mk Berglunds snabbköp Berguvsvägen 8S-958 16-07-1997 523,94 mk Berglunds snabbköp Berguvsvägen 8S-958 13-01-1997 758,88 mk Berglunds snabbköp Berguvsvägen 8S-958 08-09-1997 624,11 mk Blondel père et fils24, Kléber 67000 05-03-1997 704,97 mk Blondel père et fils24, Kléber67000 20-12-1996 592,65 mk.... Ja niin tuli toiseen järjestykseen.

Otetaanpas järjestelmällisesti koko juttu SQL-kielen rakenne on joustava: tekstin saa sijoittaa riveille vapaasti sopiva sisennys auttaa lukemista isot ja pienet kirjaimet samanarvoiset paitsi merkkijonoissa puolipiste päättää kyselyn

SQL-kielen lauseissa isot ja pienet kirjaimet ovat samanarvoiset Tämän kurssin materiaalissa pyritään noudattamaan konventiota: SQL-kielen avainsanat esitetään ISOILLA KIRJAIMILLA vain selkeyden vuoksi erottuvat paremmin

SELECT ilmoittaa mitä valitaan taulusta SELECT <sarakkeet> SELECT ; SELECT * ei sentään toimi ei ole, mitä valita valitsee kaikki sarakkeet SELECT yksi, toinen, kolmas SELECT yksi, toinen, kolmas

FROM ilmoittaa mistä taulu(i)sta valitaan taulut erotetaan pilkuilla SELECT... FROM... ; riittävä minimi

SELECT * FROM tilaukset; Tilaustunnus Asiakas Työntekijännimi Tilauspäivämäärä 02481 Vins et alcools Chevalier Buchanan, Steven 04-07-1996 10249 Toms Spezialitäten Suyama, Michael 05-07-1996 10250 Hanari Carnes Peacock, Margaret 08-07-1996 10251 Victuailles en stock Leverling, Janet 08-07-1996 10252 Suprêmes délices Peacock, Margaret 09-07-1996 10253 Hanari Carnes Leverling, Janet 10-07-1996 10254 Chop-suey Chinese Buchanan, Steven 11-07-1996... Joka rivi on kyllä pitempi, mutta kalvolla ei ole tilaa

Huomaamme tuloksena tulevat kaikki taulun rivit myös kaikki sarakkeet merkkimuotoinen tieto tasattu kentän vasempaan laitaan numeerinen tieto tasattu oikeaan laitaan tietokanta määrittelee itse sarakkeiden järjestyksen

SELECT FROM Asiakas, Tilaustunnus, Tilauspäivämäärä tilaukset; Asiakas Tilaustunnus Tilauspäivämäärä Vins et alcools Chevalier 10248 04-07-1996 Toms Spezialitäten 10249 05-07-1996 Hanari Carnes 10250 08-07-1996 Victuailles en stock 10251 08-07-1996 Suprêmes délices 10252 09-07-1996 Hanari Carnes 10253 10-07-1996 Chop-suey Chinese 10254 11-07-1996 Richter Supermarkt 10255 12-07-1996 Wellington Importadora 10256 15-07-1996....

SELECT FROM Asiakas, Tilaustunnus, Tilauspäivämäärä tilaukset; Halutut sarakkeet luetellaan SELECT-sanan jälkeen vain halutut sarakkeet luetellaan vain luetellut tulevat tulokseen kirjoitusjärjestys = niiden järjestys tuloksessa nimet erotetaan pilkulla pienten tai suurien kirjainten käyttö ei vaikuta tulokseen

SELECT FROM Tilauspäivämäärä tilaukset; Tilauspäivämäärä 04-07-1996 05-07-1996 08-07-1996 08-07-1996 09-07-1996 10-07-1996 11-07-1996

SELECT FROM DISTINCT Tilauspäivämäärä tilaukset; Tilauspäivämäärä 04-07-1996 05-07-1996 08-07-1996 09-07-1996 10-07-1996 11-07-1996 12-07-1996 15-07-1996

Mistä tiedot tulevat? tietokannoista,joiden luonnista puhutaan myöhemmin Onko muunlaista SQL:ä? Upotettu SQL on jonkin ohjelmointikielen laajennus Palauttavatko allaolevat kyselyt eri tuloksen: SELECT * FROM TILAUKSET; select * from tilaukset;

Mikä vikana allaolevissa: SELECT * SELECT * FROM tilaukset SELECT tilaustunnus tilauspäivämäärä from tilaukset; Mitkä allaolevista toimivat: SELECT * FROM tilaukset; SELECT * FROM tilaukset; SELECT * FROM tilaukset

Mirror cracked from side to side Doom has come upon me, cried The lady of Shalott