Microsoft Access: lomakkeet ja raportit - Demo 4 (Office 2007)
Näissä demoissa tutustutaan Microsoft Access 2007:iin, tehdään tauluille muutama käyttöä helpottava lisämääritys, rakennetaan lomakkeilla pieni käyttöliittymä ja tehdään pari raporttia.
Jos sinulla on vanhempi Access niin voit käyttää Access 2003 -tehtäviä.
- Demon ohjeet on tehty englanninkieliselle Accessille. Voit vaihtaa Accessin ja muiden Office-ohjelmien kieltä valitsemalla Start|All Programs|Microsoft Office|Microsoft Office Tools|Microsoft Office 2007 Language Settings
- Käynnistä Microsoft Access 2007
- Avaa aiemmissa demoissa luomasi
Resepti.mdb-tietokanta
Jos et ole ehtinyt tehdä reseptitietokantaa niin voit kopioida itsellesi mallitietokannan.
Taulujen lisämääritykset
Ennen lomakkeiden luomista kannattaa Accessissa määritellä hakutaulut (lookup) kaikkiin kenttiin joihin se on suinkin mahdollista. Näitä kenttiä ovat ainakin ne joista on määritelty viite-eheys.
Voit kokeilla tietojen syöttämistä esim. Ohje-tauluun tuplanapauttamalla taulun nimeä. Taulut löytyvät oletuksena ruudun vasemmassa reunassa olevasta palkista. Tietojen syöttämisessä on ongelmana oikean reseptin valitseminen koska pitäisi muistaa ulkoa jokaisen reseptin tunniste.
Määrittelemällä hakutaulu saadaan tietojen syöttäminen huomattavasti helpommaksi. Tunnistenumeron syötön tilalle voidaan laittaa esimerkiksi alasvetovalikko, josta voi valita reseptin nimen.
- Valitse hiiren oikealla näppäimellä Ohje-taulu. Valitse valikosta Design View
- Access saattaa ilmoittaa, että taulu on linkitetty eikä kaikkia sen ominaisuuksia voida muokata. Valitse Yes
- Valitse Reseptiid-kenttä napauttamalla sen tiedot sisältävää riviä. Siirry Lookup-välilehdelle.
-
- Valitse Display Control -alasvetovalikosta vaihtoehto Combo Box
- Valitse Row Source Type -kohtaan vaihtoehto Table/Query
- Valitse Row Source -kohtaan taulu josta reseptiid-kenttään kelpaavat arvot löytyvät eli resepti
- Bound column -kohdassa kerrotaan monesko kenttä resepti-taulussa sisältää kelpuutettavan arvon. Malliratkaisussa ReseptiID-kenttä on neljäs (4). Varmista monesko kenttä on omassa tietokannassasi.
- Column Count -kohdassa kerrotaan montako kenttää halutaan näyttää. Tähän kannattaa valita sen verran kenttiä että Bound column -kohdassa kerrottu kenttä mahtuu mukaan. Malliratkaisun mukaisessa tietokannassa valitaan neljä (4) kenttää.
- Column Heads -kohdassa voi määrätä tarvittaessa kentille otsikot. Yleensä niitä ei tarvita joten valitaan No
- Column Widths -kohdassa kerrotaan kuinka paljon esitystilaa varataan kullekin kentälle. Jätetään kaikki muut kentät piiloon paitsi oleellisin eli reseptin nimi. Eri kenttien pituudet erotetaan toisistaan puolipisteellä (;). Malliratkaisun mukaisessa tietokannassa kenttien pituudet olisivat 5cm;0cm;0cm;0cm
- List Rows kertoo montako riviä vaihtoehdoista näytetään kerrallaan
- List Width määrää alasvetovalikon leveyden
- Limit To List määrää sallitaanko myös sellaisia arvoja joita ei listasta löydy
- Sulje Design-ikkuna ja anna Accessin tallentaa muutokset
- Kokeile nyt syöttää tietoja Ohje-tauluun. Nyt voit valita reseptin kätevästi alasvetovalikosta
- Määrittele tismalleen samaan tapaan hakutaulut viite-eheysmääritysten mukaisesti (kts. kuva)
myös seuraaville:
- Haluat helpottaa reseptien syöttämistä eli valita reseptiin liittyvän ruokalajin alasvetovalikosta etkä muistella ruokalajiID-kentän arvoja. Määrittele lookup Resepti-taulun ruokalajiid-kentästä Ruokalaji-taulun ruokalajiid-kenttään. Kokeile miten uuden reseptin lisääminen onnistuu.
- Tee myös reseptiin liittyvien aineiden ja niiden määrien syöttämisestä helpompaa eli tee seuraavat lookupit:
- Lisää lookup Liittyy-taulun Resepti_Reseptiid-kentästä Resepti-taulun reseptiid-kenttään
- Lisää lookup Liittyy-taulun Aine_Aineid-kentästä Aine-taulun aineid-kenttään
- Lisää lookup Liittyy-taulun Yksikko_Lyhenne-kentästä Yksikko-taulun lyhenne-kenttään
- Kokeile lookupien toimivuutta lisäämällä kauralastujen reseptiin 3 tl tomusokeria. Lisää myös reseptiin liittyvä uusi vaihe, jossa lisätään tomusokeria.
Lomakkeet
Lomakkeilla voidaan luoda lähes millainen tahansa käyttöliittymä tietokannan päälle. Lomakkeiden avulla voi esimerkiksi helposti syöttää ja selailla tietoja. Monimutkaisten lomakkeiden tekeminen edellyttää ohjelmointitaitoja ja tarkempaa ymmärrystä graafisten käyttöliittymien toiminnasta. Tällä kurssilla tyydytään tekemään lomakkeita joihin ei vielä vaadita ohjelmointitaitoja.
- Varmista ensin, että Access listaa kaikki tekemäsi objektit eikä pelkästääm tauluja. Valitse Taulu-listauksen ylläolevasta alasvetovalikosta All Access Objects
- Valitse Create-välilehdeltä "More forms"-pudotusvalikosta kohta Form Wizard.
- Valitse Tables/Queries-alasvetovalikosta taulu, jonka päälle haluat lomakkeen muodostaa. Valitaan tässä tapauksessa ruokalaji-taulu
- Valitse Available fields-listasta kentät jotka halutaan lomakkeelle.
Valitse kaikki ruokalaji-taulun kentät
Ruokalajiid:tä ei tarvitsisi ottaa mukaan lomakkeelle mikäli kentän tyyppi olisi automaattisesti numeroituva (Autonumber). Valitse Next.
- Valitse lomakkeen ulkoasuksi Tabular
- Tabular-muodossa lomakkeella näkyy samaan aikaan useita tietueita
- Columnar-muodossa lomakkeella näkyy samaan aikaan vain yksi tietue.
- Muihin ulkoasumuotoihin voit tutustua itseksesi
- Valitse lomakkeen tyyliksi haluamasi vaihtoehto
- Anna lomakkeelle nimeksi ruokalaji
- Pääset kokeilemaan valmista lomaketta. Yritä syöttää jokin uusi ruokalaji ja sulje sen jälkeen lomake.
- Luo samaan tapaan aine ja liittyy-lomakkeet.
Useaan tauluun kohdistuvat lomakkeet
Lomakkeella voi myös tietyin rajoituksin syöttää tietoja samanaikaisesti useampaan eri tauluun. Jos taulujen välillä on selkeä yhden suhde moneen niin useampaan tauluun pohjautuvaa lomaketta voi yrittää tehdä.
Luodaan lomake jolla syötetään reseptin tiedot ja reseptiin liittyvät ohjeet
- Valitse More Forms | Form Wizard
- Valitse resepti-taulusta kaikki kentät. Valitse myös ohje-taulusta vaihenro- ja ohjeteksti-kentät
- Valitse, että lomake esitetään by resepti eli ryhmitellään reseptien mukaan. Kerrallaan lomakkeella näytetään yhden reseptin tiedot ja kaikkien siihen liittyvien ohjeiden tiedot. Valitse myös Form with subform(s). Valinta Linked forms tekisi useita eri lomakkeita jotka olisi vain yhdistetty toisiinsa
- Valitse lomakkeen ulkoasuksi Datasheet
- Valitse lomakkeen tyyliksi haluamasi tyyli
- Anna lomakkeelle nimeksi Resepti ja alilomakkeelle (subform) nimeksi ohje Subform
- Testaa valmista lomaketta. Lisää uusi resepti ja sille muutama valmistusohje.
Lomakkeiden muokkaaminen
Lisätään resepti-lomakkeeseen painikkeet joilla voi helposti avata muut resepti-tietokantaan liittyvät lomakkeet.
- Avaa resepti-lomake
- Siirry lomakkeen suunnittelunäkymään valitsemalla Home-välilehdeltä View-pudotusvalikosta "Design View". Suunnittelunäkymään pääset myös klikkaamalla lomakkeelta tyhjää kohtaa oikealla napilla ja valitsemalla valikosta "Design View".
- Voit halutessasi muokata kenttien paikkoja ja kokoa hiiren avulla. Oletuksena Access pitää kentät kiinni omassa muotissaan ja jos haluat liikutella niitä vapaasti niin valitse ensin haluamasi objekti ja sitten napauta Arrange-välilehdeltä Remove-painiketta.
- Levennä lomakealuetta hiirellä niin paljon, että painikkeille tulee tilaa oikeaan laitaan mikäli oikeassa reunassa ei ole valmiiksi tilaa.
- Lisää lomakkeelle uusi painike Design-välilehdeltä löytyvällä Button-painikkeella. Painettuasi Button-painiketta, voit piirtää haluamasi kokoisen napin lomakkeelle.
- Command Button Wizard aukeaa. Valitse Form Operations Open Form
- Valitse lomake, joka painikkeella avataan. Valitse Aine
- Valitaan, että lomake näyttää kaikki tietueet Open the form and show all the records
- Kirjoitetaan painikkeen tekstiksi Aine
- Painikkeen nimeksi voi jättää saman mitä Access ehdottaa
- Kokeile painikkeen toimintaa vaihtamalla lomake käyttötilaan
valitsemalla vasemmasta yläkulmasta View | Form view
tai
painamalla hiiren oikeaa nappia ja valitsemalla Form
View.
Jos painike ei toimi eli ei tee mitään niin kokeile auttavatko seuraavat vinkit:
- Accessin pitäisi herjata suojausasetuksista seuraavanlaisella lootalla:
Valitse dialogista Options ja esiin tulevasta dialogista Enable this content
- Jos et näe suojausasetuksista huomauttavaa laatikkoa niin sulje Access ja avaa tietokantasi uudelleen.
- Makrojen ottaminen käyttöön ja poistaminen käytöstä Office-tiedostoissa
- Luotetun tiedostosijainnin luominen, poistaminen ja muuttaminen
- Accessin pitäisi herjata suojausasetuksista seuraavanlaisella lootalla:
Alilomakkeen lisääminen
Lomakkeelle voidaan lisätä myös uusia alilomakkeita, jotka toimivat samalla tavalla kuin aiemmin velhon avulla luotu alilomake. Lisätään resepti-lomakkeelle alilomakkeena liittyy-lomake jolloin saamme helposti yhdellä ja samalla lomakkeella syötettyä kaikki reseptiin liittyvät tiedot. Ainoastaan harvemmin tarvittavat asiat kuten aineiden, yksiköiden tai ruokalajien lisäykset ja muutokset täytyy tehdä muilla lomakkeilla.
- Vaihda lomake muokkaustilaan View | Design view
- Tee lomakkeelle lisää tilaa pystysuunnassa venyttämällä lomaketta
- Lisää lomakkeelle alilomake Subform/Subquery-painikkeella Sijoita alilomake ohje-alilomakkeen alapuolelle
- SubForm Wizard käynnistyy. Valitse Liittyy-taulu.
- Valitse lomakkeita yhdistävät kentät. Form/report fields -puolelle valitse reseptiid ja Subform/report fields -puolelle valitse resepti_reseptiid eli tismalleen samat kentät jotka löytyvät viite-eheysmäärittelystäkin.
- Jätä alilomakkeen nimeksi Accessin ehdotus
- Kokeile lomakkeen toimintaa valitsemalla View | Form view. Syötä jokin uusi resepti ja sille lyhyet ohjeet ja tarvittavat valmistusaineet.
- Sulje lomake ja anna Accessin tallentaa muutokset
Raportit
Raporttien avulla voidaan tulostaa siistejä yhteenvetoja suoraan taulujen tai kyselyjen pohjalta.
Valitse ensin Office-nappi | Access options | Current Database ja poista kaikki ruksit kohdasta Name AutoCorrect Options. Ominaisuus aiheuttaa kaatuilua monimutkaisempien raporttien kanssa. Valitse myös Object Designers välilehdeltä kohdasta SQL Server Compatible Syntax valinta This database päälle. Saatat joutua sulkemaan tietokannan ja avaamaan sen uudelleen, jotta pääset muuttamaan asetuksia tai jotta ne otettaisiin käyttöön.
- Siirry Create-välilehdelle ja valitse Report Wizard.
- Valitse ruokalaji-taulusta kaikki kentät ruokalajiid-kenttä ei ole täysin välttämätön kenttä sillä ruokalajin numero ei ole tarpeellinen tieto raportissa.
- Älä lisää mitään ryhmittelyjä koska sellaisia ei järkevästi löydy pelkästä ruokalaji-taulusta.
- Järjestä raportti ruokalajin nimen mukaan
- Valitse raportin ulkoasuksi Tabular
- Valitse haluamasi tyylipohja
- Anna raportille nimeksi ruokalaji
- Esikatsele raportti. Voit muokata sarakkeiden kokoa sulkemalla esikatselun ja siirtymällä raportin suunnittelunäkymään (Design view) samalla tavalla kuin lomakkeidenkin kohdalla.
- Sulje raportti
Raportit usean taulun pohjalta
Useaan tauluun pohjautuvat raportit onnistuvat samalla tavalla kuin vastaavat lomakkeetkin.
- Siirry tekemään uutta raporttia Report Wizard-työkalun avulla
- Valitse resepti-taulusta kentät: nimi, kuvaus ja henkilomaara sekä ohje-taulusta kentät: vaihenro ja ohjeteksti.
- Ryhmittele raportti reseptien mukaan
- Älä lisää muita ryhmittelytasoja (grouping levels)
- Järjestä vaihenro-kentän mukaan
- Valitse ulkoasuksi Outline
- Valitse haluamasi tyyli
- Anna raportille nimeksi resepti
- Esikatsele raportti
Raportin ulkoasun korjaaminen
- Valitse View | Design View
- Nyt voit hiirellä siirtää haluamiasi kenttiä paikasta toiseen, muuttaa niiden kokoa tai jopa poistaa niitä.
- Levennä ohjetekstin kenttä niin leveäksi kuin mahdollista.
- Napauta hiiren oikeaa painiketta ohjeteksti-kentän päällä ja valitse
Properties. Ruudun oikeaan reunaan avautuu paneeli,
jossa näkyy kulloinkin valitun kentän ominaisuuksia.
- Valitse Format-välilehti
- Muuta Can Grow -kohdan arvoksi Yes, jonka jälkeen ohjeteksti-kenttä voi laajeta sen mukaan kuinka paljon tekstiä siihen on tulossa
- Voit tutkia muitakin tarjolla olevia ominaisuuksia mutta niiden toimintaan joudut perehtymään tarkemmin Accessin avustuksen avulla
- Sulje Properties-ikkuna
- Kokeile raportin uutta ulkoasua valitsemalla View | Print Preview
Kaavion lisääminen raporttiin
- Harjoittele kaavion lisäämistä raporttiin
- Raportteihin voidaan lisätä kaavioita. Luo raportti ja valitse Design view ja valitse Design | Insert Chart.
- Valitse raportistasi kohta johon haluat kaavion lisätä ja paina vasenta hiiren näppäintä.
- Sinulle avautuu kaavionluontivelho, jossa pystyt määrittelemään haluamasi kentät, jotka sisällytetään kaavioon.
- Valitse haluamasi kentät ja kaaviotyyppi.
- Voit esikatsella valitsemaasi kaaviota ja määritellä siihen halutut laskutoimitukset kentistä (esim. sum, count), kaksoisnäpäyttämällä kyseistä kenttää kaavion alapuolella. Voit raahata ja pudottaa haluamasi kentän sarjaan, jonka mukaan haluat kaaviosi luoda.
- Raporttia ja kaaviota yhdistävien kenttien täytyy esiintyä raportissa
- Huomaa ettei kaavio päivity oikein vielä suunnittelunäkymässä. Palaa varsinaiseen raporttinäkymään nähdäksesi kaavion oikein.
Dynaamiset raportit
Accessin oman raporttivelhon kyvyt loppuvat joskus kesken jos raporttiin yrittää liittää useita tauluja ja vielä ryhmitellä niiden tietoja. Monesti onkin viisainta tehdä raporttia varten oma kysely, joka hoitaa tietojen yhdistämisen useammasta taulusta, ja luoda sitten raportti suoraan tämän kyselyn pohjalta.
Luodaan seuraavaksi dynaaminen kysely, joka toimii raportin pohjana.
- Aloita uusi SQL-kysely (engl. Query).
- Valitse Create-välilehdeltä kohta Query Design ja sulje esiin avautuva Show Table (suom. Näytä taulukko) -ikkuna.
- Valitse tämän jälkeen SQL-näkymä vasemman yläkulman
SQL-painikkeella ja kopioi seuraava SQL-kysely kyselyn pohjaksi:
SELECT * FROM Resepti WHERE ReseptiID = 1
- Kokeile ajaa kysely. Tallenna kyselysi jollakin nimellä!
- Tee yksinkertainen raportti (engl. Report), joka pohjautuu edellä tekemääsi kyselyyn. Raportin voit laatia esimerkiksi ohjatun toiminnon avulla kuten edellä, valitset vain ensimmäisessä vaiheessa jonkin taulun sijasta pudotusvalikosta Query: (kyselyn nimi). Tallenna raportti jollakin nimellä.
- Avaa Resepti-lomake
- Tarkista lomakkeen reseptiID-kentän oikea nimi (engl. name). Nimen pitäisi olla reseptiID, joten muuta se tarvittaessa. Kentän ominaisuuksia pääset tarkastelemaan rakennenäkymässä (engl. Design View) tuplanapauttamalla kenttää.
- Lisää lomakkeelle komentopainike ja valitse painikkeeseen liittyväksi toiminnoksi raporttitoimintojen alta löytyvä raportin esikatselu (engl. Report operations | Preview Report). Lisää painikkeeseen teksti Tulosta resepti.
- Kokeile painikkeen toimintaa menemällä takaisin lomakenäkymään (engl. Form View).
- Avaa edellä tekemäsi kysely valitsemalla vasemman reunan
paneelin otsikossa olevasta pudotusvalikosta kohta "Queries" ja
avaamalla kysely. Muuta sitä seuraavan esimerkin mukaisesti:
SELECT * FROM Resepti WHERE ReseptiID = [Forms]![Resepti]![ReseptiID]
[Forms]![Resepti]![ReseptiID]-kohdalla kyselyssä määritellään, että kyselyn valuuttatieto otetaan Reseptit-lomakkeelta ReseptiID-nimisestä kentästä. - Siirry nyt lomakkeella haluamasi reseptin kohdalle ja kokeile tekemääsi raporttia. Raportissa pitäisi nyt näkyä aina lomakkeella näkyvissä olevan reseptin tiedot. Olet tehnyt hyvin yksinkertaisen dynaamisen kyselyn ja raportin :)
Yhteenvedot raporteissa
Raporteissa voi laskea yhteenvetoja eri kenttien tiedoista.
- Luo uusi raportti, joka kertoo paljonki kutakin ainetta tarvitaan yhteensä. Luo raportti Aine- ja Liittyy-taulujen pohjalta.
- Valitse raporttiin kentät: Nimi, Maara ja Yksikko_lyhenne.
- Ryhmittele aineen ja yksikön mukaan.
- Valitse Summary options. Tee yhteenveto (summary) määrästä eli laske määrät yhteen. Valitse näytettäväksi pelkkä yhteenveto (summary only).
Raportin ulkoasu
- Siisti edellisen raporttisi ulkoasua. Siirry muokkaus-tilaan valitsemalla View|Design View.
- Poista raportista ylimääräiset turhat tekstit.
- Siirrä summan laskeva kenttä Yksikko_lyhenne Header-osaan heti yksikko_lyhenne-kentän viereen.
- Piilota pois näkyviltä Yksikko_lyhenne Footer ja AineID Footer. Piilottaminen onnistuu valitsemalla Design-välilehdeltä kohta "Group & Sort". Toiminto avaa ruudun alareunaan ikkunan, josta pystyt määrittämään kummankin ryhmittelyalueen ominaisuuksia. Klikkaa AineID-kohtaa, valitse More ja muuta kohta "With a footer section" muotoon "Without a footer section". Access vielä varmistaa, että varmasti haluat poistaa alueen. Vastaa Yes. Toista sama Yksikko_Lyhenne-alueelle.
- Muuta raportin otsikoksi Report Header-osaan teksti Ainemäärät.
- Kokeile nyt miltä raportti näyttää valitsemalla View|Print preview.
Lisätehtävät
Jos aikaa vielä jäi niin täydennä tietokantasovelluksesi toimivuus seuraavilla toimenpiteillä:
- Luo tavallinen lomake myös taululle yksikko.
- Lisää reseptilomakkeeseen painikkeet yksikko- ja ruokalaji-lomakkeiden avaamiseksi.
- Lisää painikkeet myös raporttien avaamiseksi.
Käyttäjien kommentit
Olisin kokenut avuksi sen, jos englanninkielisten valikkojen ja valintojen viereen olisi kirjoitettu sulkuihin suomenkielinen valinta, esim. Valitse valikosta Design View (Rakennenäkymä)