Triggereiden käyttö

MySQL aloittelija

Miten voin luoda kahden eri kannoissa olevien taulujen välille triggerin, joka "nuuskii" ekassa taulussa tapahtuvia muutoksia tietyssä kentässä (eli sarakkeessa) ja päivityksen tapahtuessa (UPDATE tai INSERT) tämä käy päivittämässä myös toisessa taulussa olevat näitä vastaavat tiedot? Jos mahdollista niin jokin yksinkertaistettu esimerkki. Syntaksi lienee jotakin tyyliin (?):


CREATE TRIGGER triggerin_nimi
AFTER UPDATE ON taulu_1
FOR EACH ROW
BEGIN
UPDATE taulu_2
SET jokin_kenttä = jokin_toinen_kenttä
END


Olenko ihan hakoteillä...?
Kiitos vastauksista.

5

538

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • lähellä

      >Olenko ihan hakoteillä...?

      Et suinkaan.

      Pienenä tarkennuksena voi tietysti mainita että trigger ei ole mitenkään sidottu kahden taulun välille vaan sen liipaisun aiheuttamia toimia voi tehdä mille tahansa taululle.

      Lisätietoja tuolta:

      http://dev.mysql.com/doc/refman/5.0/en/create-trigger.html

    • I.Proqatlis
      • MySQL aloittelija

        Ongelma johtui DELIMITER:n puuttumisesta. Nyt seuraa jatkokysymys: miten saan selville, mitä riviä triggeri kulloinkin on käsittelemässä? Saako tämän jollakin tavalla esim. muuttujan sisällöksi, jota sql-koodi käyttää eri toimenpiteisiin identifioidessaan mille riville vastaavat tiedot pitää päivittää toisessa taulussa?


      • I.Proqatlis
        MySQL aloittelija kirjoitti:

        Ongelma johtui DELIMITER:n puuttumisesta. Nyt seuraa jatkokysymys: miten saan selville, mitä riviä triggeri kulloinkin on käsittelemässä? Saako tämän jollakin tavalla esim. muuttujan sisällöksi, jota sql-koodi käyttää eri toimenpiteisiin identifioidessaan mille riville vastaavat tiedot pitää päivittää toisessa taulussa?

        Sain vaikutelman, ettet oikein ymmärtänyt esimerkeissä olleita ideoita. Katsotaanpa tätä hieman tarkemmin.

        Meillä on siis seuraavat taulut:

        Pelaajat
        --------
        id
        etunimi
        sukunimi
        tehdyt_maalit
        syotetyt_maalit

        Maalit
        ------
        aika
        tekija (pakollinen kenttä, siis NOT NULL)
        syottaja (ei pakollinen kenttä, koska syöttäjää ei välttämättä ole, NULL-arvot sallittuja)


        Meillä on kolme triggeriä, jotka reagoivat, kun maalit-taulussa tapahtuu jotain – kun rivejä lisätään, poistetaan tai päivitetään. Tämä alempana oleva triggeri nuuskii, tapahtuiko tekijän tai syöttäjän muutos. Jos tapahtui, niin pelaajat-taulussa olevia laskureita päivitetään.

        Seuraava on tärkeä ymmärtää:

        Mistä tietää, muutettiinko maalin tekijää?
        Systeemillä on tiedossaan kenttien arvot ennen ja jälkeen päivityksen. Näihin voidaan viitata käyttäen etuliitteitä NEW tai OLD. Triggerin ensimmäisellä rivillä on tämä tutkimus:

        if NEW.tekija OLD.tekija.

        Jos todetaan tämän olevan totta – siis tekijää ollaan vaihtamassa – tehdään kaksi päivitystä pelaajat-tauluun. Aluksi vähennetään 1 maali siltä pelaajalta, jolle maali ensin oli kirjattu. Where-ehdossa kirjoitetaan tällöin id = OLD.tekija. Tämän jälkeen lisätään 1 maali sille pelaajalle, joka korjattiin maalintekijäksi. Tähän viitataan sanomalla id = NEW.tekija.

        Siis kulloinkin triggerissä päivitettävänä olevan rivin arvoihin voidaan viitata käyttämällä etuliitteitä NEW tai OLD. Tätähän sinä et kaiketi oikein ymmärtänyt? Huomaa myös, että jos rivi on uusi, niin vain NEW-arvoja on olemassa. Poistoa tehtäessä vain OLD-arvot ovat olemassa.

        Sitten seuraa vastaava tutkimus maalin syöttäjästä. Tässä tehdään samantapaiset operaatiot kuin edellä.


        CREATE TRIGGER tekija_korjaus after UPDATE ON maalit
        FOR EACH ROW

        BEGIN

        if NEW.tekija OLD.tekija then
        UPDATE pelaajat
        SET tehdyt_maalit = tehdyt_maalit - 1
        WHERE id = OLD.tekija;

        UPDATE pelaajat
        SET tehdyt_maalit = tehdyt_maalit 1
        WHERE id = NEW.tekija;

        end if;


        if ifnull(NEW.syottaja, 0) ifnull(OLD.syottaja, 0) then

        if OLD.syottaja is not null then
        UPDATE pelaajat
        SET syotetyt_maalit = syotetyt_maalit - 1
        WHERE id = OLD.syottaja;
        end if;

        if NEW.syottaja is not null then
        UPDATE pelaajat
        SET syotetyt_maalit = syotetyt_maalit 1
        WHERE id = NEW.syottaja;
        end if;

        end if;

        END


      • MySQL aloittelija
        I.Proqatlis kirjoitti:

        Sain vaikutelman, ettet oikein ymmärtänyt esimerkeissä olleita ideoita. Katsotaanpa tätä hieman tarkemmin.

        Meillä on siis seuraavat taulut:

        Pelaajat
        --------
        id
        etunimi
        sukunimi
        tehdyt_maalit
        syotetyt_maalit

        Maalit
        ------
        aika
        tekija (pakollinen kenttä, siis NOT NULL)
        syottaja (ei pakollinen kenttä, koska syöttäjää ei välttämättä ole, NULL-arvot sallittuja)


        Meillä on kolme triggeriä, jotka reagoivat, kun maalit-taulussa tapahtuu jotain – kun rivejä lisätään, poistetaan tai päivitetään. Tämä alempana oleva triggeri nuuskii, tapahtuiko tekijän tai syöttäjän muutos. Jos tapahtui, niin pelaajat-taulussa olevia laskureita päivitetään.

        Seuraava on tärkeä ymmärtää:

        Mistä tietää, muutettiinko maalin tekijää?
        Systeemillä on tiedossaan kenttien arvot ennen ja jälkeen päivityksen. Näihin voidaan viitata käyttäen etuliitteitä NEW tai OLD. Triggerin ensimmäisellä rivillä on tämä tutkimus:

        if NEW.tekija OLD.tekija.

        Jos todetaan tämän olevan totta – siis tekijää ollaan vaihtamassa – tehdään kaksi päivitystä pelaajat-tauluun. Aluksi vähennetään 1 maali siltä pelaajalta, jolle maali ensin oli kirjattu. Where-ehdossa kirjoitetaan tällöin id = OLD.tekija. Tämän jälkeen lisätään 1 maali sille pelaajalle, joka korjattiin maalintekijäksi. Tähän viitataan sanomalla id = NEW.tekija.

        Siis kulloinkin triggerissä päivitettävänä olevan rivin arvoihin voidaan viitata käyttämällä etuliitteitä NEW tai OLD. Tätähän sinä et kaiketi oikein ymmärtänyt? Huomaa myös, että jos rivi on uusi, niin vain NEW-arvoja on olemassa. Poistoa tehtäessä vain OLD-arvot ovat olemassa.

        Sitten seuraa vastaava tutkimus maalin syöttäjästä. Tässä tehdään samantapaiset operaatiot kuin edellä.


        CREATE TRIGGER tekija_korjaus after UPDATE ON maalit
        FOR EACH ROW

        BEGIN

        if NEW.tekija OLD.tekija then
        UPDATE pelaajat
        SET tehdyt_maalit = tehdyt_maalit - 1
        WHERE id = OLD.tekija;

        UPDATE pelaajat
        SET tehdyt_maalit = tehdyt_maalit 1
        WHERE id = NEW.tekija;

        end if;


        if ifnull(NEW.syottaja, 0) ifnull(OLD.syottaja, 0) then

        if OLD.syottaja is not null then
        UPDATE pelaajat
        SET syotetyt_maalit = syotetyt_maalit - 1
        WHERE id = OLD.syottaja;
        end if;

        if NEW.syottaja is not null then
        UPDATE pelaajat
        SET syotetyt_maalit = syotetyt_maalit 1
        WHERE id = NEW.syottaja;
        end if;

        end if;

        END

        Tämä tieto oli ratkaiseva!

        "Systeemillä on tiedossaan kenttien arvot ennen ja jälkeen päivityksen. Näihin voidaan viitata käyttäen etuliitteitä NEW tai OLD."

        Kiitän!


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

    Luetuimmat keskustelut

    1. Ihanasti alkoi aamu: SDP:n kaula kokoomukseen jo 6,9 %-yks

      Lindtmanin I hallitus on tukevasti jytkyttämässä laittamaan Suomi kuntoon Orvon täystuhohallituksen jäljiltä, jonka kann
      Maailman menoa
      442
      2936
    2. Olen niin kesken

      Omien asioiden suhteen etkä voi odottaa loputtomiin. Mun on muutenkin niin vaikea suhun luottaa vaikka joku ihme syvyys
      Ikävä
      20
      2546
    3. Teidän persujen pitäisi välillä miettiä kuinka Suomen talous saataisiin kuntoon

      Ja lopettaa tuo tyhjänpäiväinen maahanmuuttajista höpöttäminen. Teillä on sentään rahaministerin salkku tällä kierroksel
      Maailman menoa
      137
      2225
    4. Minkä ikäinen

      Minkä ikäinen on kaipauksesi kohde?
      Ikävä
      125
      1991
    5. Tietääkö joku ylläpidosta?

      Miten näillä palstoilla tomii tuo ylläpito, onko sitä yli päätään olemassa vai ovatko huhut totta että on palstan kirjoi
      Sinkut
      249
      1639
    6. Kaninkolojen vaikutus?

      Vinkki sinkkumiehille: jos haluatte kunnollisen täysijärkisen naisen, niin kaivautukaa ulos kaninkoloistanne ja parantak
      Sinkut
      208
      1284
    7. Auttaja paikalla. Kerro huolesi. (Osa 2)

      Voin auttaa sinua näkemään tilanteesi uudesta näkökulmasta. Voin antaa lohtua, toivoa ja rohkeutta. Olen elänyt maan pä
      Ikävä
      186
      1240
    8. Kuka omistaa entisen Veljeskodin?

      Kenellä on varaa pitää hiljattain remontoitua rakennusta tyhjillään? Tehdäänkö siitä Suomen kallein kirpputori vai mikä
      Ähtäri
      7
      1235
    9. Martina ei mennyt naimisiin

      IS 17.9: Martinan häät peruuntui, tajusi, ettei ollut oikea aika. Rahat meni hevosiin. On edelleen parisuhteessa Yhdysva
      Kotimaiset julkkisjuorut
      151
      1223
    10. Persut ei kestä heidän johtajistaan tehtyä huumoria

      Laajalti tiedostettu tosiasia on, että autoritaariset johtajat ja erinäiset diktaattorit eivät kestä heidän kustannuksel
      Maailman menoa
      28
      1198
    Aihe