Microsoft Access: lomakkeet ja raportit - Demo 4
Näissä demoissa tutustutaan Microsoft Accessiin, tehdään tauluille muutama käyttöä helpottava lisämääritys, rakennetaan lomakkeilla pieni käyttöliittymä ja tehdään pari raporttia.
Mallivideot
- access1.wmv 1.7M
- access2.wmv 1.4M
- access3.wmv 1.6M
- Käynnistä Microsoft Access (Start|Programs|Microsoft Access)
- Avaa aikaisemmin luomasi Resepti.mdb
Jos et ole ehtinyt tehdä reseptitietokantaa niin voit kopioida itsellesi mallitietokannan.
Taulujen lisämääritykset
Ennen lomakkeiden luomista kannattaa Accessissa määritellä hakutaulut 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ä. 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:
- Resepti-taulun ruokalajiid-kentästä haku Ruokalaji-taulun ruokalajiid-kenttään
- Liittyy-taulun Resepti_Reseptiid-kentästä haku Resepti-taulun reseptiid-kenttään
- Liittyy-taulun Aine_Aineid-kentästä haku Aine-taulun aineid-kenttään
- Liittyy-taulun Yksikko_Lyhenne-kentästä haku Yksikko-taulun lyhenne-kenttään
- Kokeile hakutaulujen 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.
- Valitse Forms-välilehti
- Valitse Create form by using 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 Create form by using 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
- Valitse View|Design View
- Levennä lomakealuetta hiirellä niin paljon, että painikkeille tulee tilaa oikeaan laitaan.
- Lisää lomakkeelle uusi painike Command Button-painikkeella
- 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 View|Form view
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 Tools | Options | General ja poista kaikki ruksit kohdasta Name AutoCorrect. Ominaisuus aiheuttaa kaatuilua monimutkaisempien raporttien kanssa. Valitse myös Tables/Queries välilehdeltä kohdasta SQL Server Compatible Syntax valinta This database päälle.
- Siirry Reports-välilehdelle
- Valitse Create report by using 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
- Sulje raportti
Raportit usean taulun pohjalta
Useaan tauluun pohjautuvat raportit onnistuvat samalla tavalla kuin vastaavat lomakkeetkin.
- Siirry Reports-välilehdelle
- Valitse Create report by using wizard
- 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 1
- 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
- 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
Monimutkaisemmat raportit
Accessin oman raporttivelhon kyvyt loppuvat kesken jos raporttiin yrittää liittää useita tauluja ja vielä ryhmitellä niiden tietoja. Yleensä viisainta onkin tehdä raporttia varten oma kysely, joka hoitaa tietojen yhdistämisen useammasta taulusta, ja luo raportin suoraan tämän kyselyn pohjalta.
- Luodaan ensimmäisenä kysely raportin pohjaksi. Valitse Queries-välilehti.
- Valitse Create query in Design view
- Sulje Show table -dialogi
- Valitse View|SQL View
- Nyt voit kirjoittaa tavallisen SQL-kyselyn. Kirjoita kysely, joka
listaa reseptin nimen ja reseptiin liittyvien aineiden nimet, ainemäärät ja ainemäärän yksiköt reseptin nimen ja aineiden nimien mukaan järjestettynä.
Saman nimiset kentät on muutettava toisiksi raporttien takia. Ole tarkkana, että AS-sanan jälkeen tuleva teksti alkaa isolla kirjaimella. Tämä lienee jokin bugi Accessissa.SELECT resepti.nimi AS Resepti, liittyy.maara, liittyy.yksikko_lyhenne, aine.nimi AS Aine FROM Resepti, liittyy, aine WHERE Resepti.reseptiid = liittyy.resepti_reseptiid AND liittyy.Aine_aineid = Aine.aineid ORDER BY resepti.nimi, aine.nimi ;
- Voit kokeilla kyselyn suorittamista valitsemalla Query|Run. Takaisin SQL-tilaan pääset valitsemalla View|SQL view
- Saatuasi kyselyn kuntoon tallenna se reseptin_aineet-nimellä
- Luo uusi raportti
- Valitse raporttiin edellä tekemäsi kyselyn kaikki kentät
- Ryhmittele raportti reseptin mukaan
- Älä lisää muita ryhmittelytasoja
- Järjestä aineen mukaan
- Valitse ulkoasuksi Outline 1
- Valitse haluamasi tyyli
- Anna raportille nimeksi reseptin_aineet
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.
- 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 View|Sorting and Grouping. Aukeavasta dialogista voi valita kummankin ryhmittelyalueen ja vaihtaa niiden ominaisuuksista (group properties) kohdan Group Footer arvoksi No. Access vielä varmistaa, että varmasti haluat poistaa alueen. Vastaa Yes.
- 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