Jotenkin järkevästi...

tehtyä...

On kolme taulua, opiskelijat, kurssit ja ilmoittautumiset:

Opiskelija (id, nimi);
Kurssi (id, nimi);
Ilmoittautumiset (id, id_kurssi, id_opiskelija);


Nyt pitäisi jotenkin järkevästi tulostaa luettelo opiskelijoista ja mille kursseille kukin on ilmoittautunut, jotenkin näin:

Matti Virtanen - matem, ruotsi, liik, kuv, hist
Katri Savolainen - hist, matem, usk, eng
Anna Ström - ruotsi, eng, matem
jne...

Miten tämä onnistuisi mahdollisimman "nopeasti/tehokkaasti"

Yksi vaihtoehto on tietenkin hakea ensin kaikki opiskelijat ja sitten jokaisen opiskelijan ilmoittautumiset, mutta silloin kyselyiden määrä olisi aivan hirveä. Onko parempia ideoita?

Opiskelijaoita ja ilmoittautumisia on tosi paljon!!!

2

312

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • I. Proqatlis

      Kouluesimerkki moni-moneen -relaatiosta, joka puretaan luomalla opiskelijoiden ja kurssien väliin ilmoittautumiset-taulu. (Miksi tuossa ilmoittautumiset-taulussa on sarake 'id'? Ei sitä tarvita.)

      Tauluilla tulee olla uniikit indeksit, jotka tässä tapauksessa koostuvat id-sarakkeista. Ilmoittautumiset-taulun uniikki indeksi muodostuu sen molemmista sarakkeista. Seuraava SQL-operaatio on aika tehokas:

      select
          opiskelija.nimi, kurssi.nimi
      from
          opiskelija, kurssi, ilmoittautumiset
      where
          ilmoittautumiset.id_opiskelija = opiskelija.id and
          ilmoittautumiset.id_kurssi = kurssi.id
      order by
          ilmoittautumiset.id_opiskelija;


      Ratkaisinko kotiläksysi ;-)

      • tohlo

        > (Miksi tuossa ilmoittautumiset-taulussa on
        > sarake 'id'? Ei sitä tarvita.)

        (En ole alkuperäinen kysyjä.)

        Vaikkapa siksi, että opiskelija voisi ilmoittautua samalle kurssille useampaan kertaan. Laiska opiskelija kun ei heti pääse kurssista läpi. ;-) Tosin arvosteluita ym. ei tässä ehkä haluttukaan tallentaa eli mahdollisesti useampaa kurssi-henkilö -paria ei tarvitse salliakaan, joten tässä mielessä olisit siis oikeassa.

        Niin, ja vastauksesi ei ilmaissut sitä, että sql-kyselyn tulos (1. rivi: "Matti, usk.", 2. rivi: "Matti, eng.", jne) pitää käyttöliittymässä näyttämistä varten purkaa vielä kysyjän haluamaan "näyttävämpään" muotoon ("Matti - usk, eng, hist"). Tämä tosin taisi olla jo itsestään selvää. ;)


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Miksi persuilla ei ole firmoja?

      Kuten vasemmisstolaisilla, esim. Sannalla MA\PI. Eikö ole aika erikoista?
      Maailman menoa
      82
      7076
    2. Persut hommasivat Suomeen 35 000 pientä lasta v. 2015

      Onko Riikka Purra nyt tavoittelemassa tätä samaa historiallista persujen utopiaa? Purram kaksinaamaisessa pelissä vaadit
      Maailman menoa
      26
      7043
    3. Purran tuhoja tuskin saadaan koskaan korjatuksikaan

      Purra on aiheuttanut Suomen taloudelle karmaisevat tuhot. Sen lisäksi Purra on ajanut myös suuren osan Suomen kansasta k
      Maailman menoa
      106
      6143
    4. Persujen kaksoisstandardit: Räsäsen uhkailu paha, Virran uhkailu hyvä

      Tässä taas nähdään kuinka kaksinaamaista porukkaa persut ovat. Mitäs persut tähän?
      Maailman menoa
      45
      5394
    5. Miksette persut irtisanoudu Kirkin lausunnoista?

      Kirkhän muun muassa vaati raiskattuja naisia pidättäytymään abortista ja vaimoja alistumaan aviomiestensä tahtoon. Mik
      Maailman menoa
      84
      5228
    6. Demarikultin uhri kertoo

      Demarikultin uhri kertoo: “En saanut mennä edes suihkuun ilman lupaa” – Seksuaalisen hyväksikäytön uhri kertoo vuosistaa
      Maailman menoa
      62
      5182
    7. Miksi vasemmistolaiset eivät omista yhtään firmaa?

      Vasemmistolaiset eivät omista yhtään firmaa joka työllistäisi ihmisiä. Miksi? No siksi, että jos vasemmistolainen perus
      Maailman menoa
      40
      5098
    8. Sanna valittiin Euroopan huonoimmaksi pääministeriksi

      Sannan kaudella Suomi oli ainut maa missä bkt laski. Kannattaa huomata, että luvut valitsi Sannan huonoimmaksi. Ihmiset
      Maailman menoa
      27
      4585
    9. Purran vuoro kiihoittua Lepomäen sääristä

      "Ulkoministeri Elina sanoo, ettei muuta pukeutumistaan sen mukaan, kenet tapaa, ja että hän ei suostuisi peittämään kasv
      Maailman menoa
      16
      3457
    10. Vasemmistolaiset paskat eivät nousseet seisomaan kun Akaan kaupunginvaltuusto

      vietti hiljaisen hetken Charlie Kirkin muistoksi https://www.aamulehti.fi/uutiset/art-2000011523016.html
      Maailman menoa
      300
      3370
    Aihe