taulukoiden yhdistäminen

Arvi

Laitanpa tämän kysymyksen hädissäni tännekin.

Minulla on Accessissa kaksi eri taulukkoa, joissa on samat kenttärakenteet ja molemmissa on satoja tietueita. Osa tietueista on samoja, osa ei. Haluaisin yhdistää taulukot. Yhdistämiskriteerit: Jos alkuperäisen taulukon kentässä ”maksanut” on kyllä, alkuperäisen taulukon tietueessa kaikki tiedot pysyvät ennallaan.
Jos uudessa taulukossa on nimi jota ei ole alkuperäisessä taulukossa, tietue lisätään.
Jos uudessa taulukossa on alkuperäisen taulukon kanssa yhteisiä tietueita (joilla nimi kentässä sama tieto) käytetään uuden taulukon tietuetta. Mikään tietue ei tule kahta kertaa mukaan yhdistettyyn taulukkoon.

Selviänkö yhdistämisestä sql-kielen avulla? Tai jollain muulla keinolla ilman koodin tekoa? Olisiko tarvittava koodi vaikea kirjoittaa?

8

657

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • vjh

      Minä tekisin tuon accessin visual basicilla. Tai voi sen javallakin tehdä. Logiikka olisi sellainen, että luetaan ekasta taulusta (ei taulukosta) tietue. Sitten katsotaan, löytyykö vastaavaa siitä toisesta taulusta. Jos ei löydy, lisätään. Jos löytyy, päivitetään. Sitten luetaan ekasta taulusta seuraava tietue jne..
      Paljonko maksat, niin teen tuon koodin javalla tai accessilla.

    • ~~~

      -- Jos alkuperäisen taulukon kentässä ”maksanut”
      -- on kyllä, alkuperäisen taulukon tietueessa
      -- kaikki tiedot pysyvät ennallaan.

      select *
      from alkuperäinen_taulu at
      where at.maksanut = 'kyllä'

      union

      -- Jos uudessa taulukossa on nimi jota ei ole
      -- alkuperäisessä taulukossa, tietue lisätään.

      select *
      from uusi_taulu ut
      where not exists
      ( select * from alkuperäinen_taulu at
      where at.nimi = ut.nimi )

      union

      -- Jos uudessa taulukossa on alkuperäisen taulukon
      -- kanssa yhteisiä tietueita (joilla nimi kentässä
      -- sama tieto) käytetään uuden taulukon tietuetta

      select *
      from alkuperäinen_taulu at
      where not at.maksanut = 'kyllä' and
      exists
      ( select * from uusi_taulu ut
      where at.nimi = ut.nimi )

      Olen kuumeessa enkä testannut, joten bugeja on aivan varmasti. Lisäksi tein tuon yhden kohdan tahallaan helppolukuiseksi, mutta suorituskyvyllisesti hieman optimoimattomaksi.

      Tähdet pitää korvata sarakkeiden nimillä (paitsi exists-lauseissa). Joku terveempi voi fiksailla.

      • ~~~

        Heti ensimmäisellä lukukerralla huomasin bugin tuossa. Viimeisessä lauseessahan haettiin siis uuden taulun tietoja:

        union

        -- Jos uudessa taulukossa on alkuperäisen taulukon
        -- kanssa yhteisiä tietueita (joilla nimi kentässä
        -- sama tieto) käytetään uuden taulukon tietuetta

        select *
        from uusi_taulu ut
        where exists
        ( select * from alkuperäinen_taulu at
        where not at.maksanut = 'kyllä'
        and at.nimi = ut.nimi )

        Joo, nyt mä lopetan tän kuumekoodailun :)


      • Sivullinen
        ~~~ kirjoitti:

        Heti ensimmäisellä lukukerralla huomasin bugin tuossa. Viimeisessä lauseessahan haettiin siis uuden taulun tietoja:

        union

        -- Jos uudessa taulukossa on alkuperäisen taulukon
        -- kanssa yhteisiä tietueita (joilla nimi kentässä
        -- sama tieto) käytetään uuden taulukon tietuetta

        select *
        from uusi_taulu ut
        where exists
        ( select * from alkuperäinen_taulu at
        where not at.maksanut = 'kyllä'
        and at.nimi = ut.nimi )

        Joo, nyt mä lopetan tän kuumekoodailun :)

        Mä olisin yrittänyt Javalla tai Visuaalilla. Voiko toi tosiaan toimia noinkin? Selitä lisää


      • ~~~
        Sivullinen kirjoitti:

        Mä olisin yrittänyt Javalla tai Visuaalilla. Voiko toi tosiaan toimia noinkin? Selitä lisää

        Kyllä sen noin saa pelaamaan. Unioneita tosin yleensä pidetään pahana tapana, mutta näin kertaluonteisissa hommissa ne ovat ihan ok.

        Union-kyselyn syntaksi löytyy vaikkapa täältä:

        http://www.mysql.com/doc/en/UNION.html


    • Uno

      Mua kiinnostais kans ihan periaatteessa voisko ton klaarata ilman ohjelmointia eli pelkällä sql-komentokielellä. Gurut, kertokaa ihmeessä.

    • funky

      SELECT INTO:lla saat tehtyä haun toiseen tauluun, ja antamasi ehdon ollessa voimassa insertoitua toisen taulun kyselyn tulos ensimmäiseen tauluun.

      SELECT * FROM tblYksi INNER JOIN tblKaksi ON tblYksi.nimi != tblKaksi.nimi WHERE maksanut!=kyllä INTO tblYksi VALUES (yy, kaa, koo...)

      ääh, en jaksa ihan loppuun asti miettiä, flunssa vie voimat täälläkin :(

    • Arvi (avaaja)

      EN onnistunut vielä, vaikka yritinkin koko ajan - miten se meni?Arvi

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

    Luetuimmat keskustelut

    1. Vain vasemmistolaiset rakennemuutokset pelastavat Suomen

      Kansaa on ankeutettu viimeiset 30+ vuotta porvarillisella minäminä-talouspolitiikalla, jossa tavalliselta kansalta on ot
      Maailman menoa
      128
      3912
    2. Purra on kantanut vastuuta täyden kympin arvoisesti

      Luottoluokituksen lasku, ennätysvelat ja ennätystyöttömyys siitä muutamana esimerkkinä. Jatkakoon hän hyvin aloittamaans
      Maailman menoa
      14
      3361
    3. Haluaisin rakastaa sinua

      Ja olla sinulle se oikea... Rakastan sinua 💗💗💗
      Ikävä
      19
      3285
    4. onko kaivattusi

      vaarallinen? :D
      Ikävä
      79
      3237
    5. Persut huutaa taas: "kato! muslimi!"

      Persut on lyhyessä ajassa ajaneet läpi kaksi työntekijöiden oikeuksien heikennystä, joita se on aiemmin vastustanut. Pe
      Maailman menoa
      57
      3214
    6. Menen nyt koisimaan

      Ja en ehkä palaa tänne. Asia on nyt loppuunkäsitelty ja totuus tuli ilmi
      Ikävä
      29
      2875
    7. Tiedätkö mihin

      Ominaisuuksiin rakastuin sinussa?
      Ikävä
      47
      2677
    8. Olisiko sinulla

      Jonossa vaihtoehtoja, ehkä
      Ikävä
      54
      2617
    9. Pieni galluppi

      Mitäs lahjaa odotat joulupukilta.
      Ikävä
      67
      2397
    10. Mitä tuntemuksia

      Rakkaasi ääni herättää?
      Ikävä
      19
      2337
    Aihe