millainen rakenne mySQL taululle??

juha

Tarkoituksena on rakentaa eräälle sivulle uutispalsta mihin voi laittaa myös kuvia.
tauluun tulisi:
-uutisen ID
-uutisen otsikko
-uutisen kirjoittaja
-uutisen päivämäärä (timestamp?)
-uutisteksti

Mitä muotoa(text,varchar...?) ylläolevien sarakkeiden olisi järkevintä olla?

Uutiseen on siis mahdollista myös liittää kuvia, tietokantaan ajattelin tallentaa vain kuvien nimet.
Tuleeko kaikkien kuvien 1..n nimet yhteen vai useampaan sarakkeeseen. Paras olisi ilmeisesti saada kaikkien kuvien nimet samaan sarakkeeseen, mutta miten tämä toteutetaan??

Toivottavasti saitte selvää ja toivottavasti joku osaisi vielä auttaa aloittelijaa...

5

596

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • uutinen ja kuva

      Itse tekisin tällaisen:

      CREATE TABLE uutinen (
      uutinenId INT NOT NULL AUTO_INCREMENT,
      uutinenOtsikko varchar(250) NOT NULL,
      uutinenKirjoittaja varchar(50) NOT NULL,
      uutinenPvm timestamp,
      uutinenTeksti TEXT,
      PRIMARY KEY (uutinenId)
      );

      timestampin tilalle voi ajatella jotain muutakin tekstiä.

      Kuville oma taulu:

      CREATE TABLE kuva (
      kuvaId INT NOT NULL AUTO_INCREMENT,kuva_uutinenId INT REFERENCES uutinen.uutinenId,
      kuvaTiedostonimi varchar(250) NOT NULL,
      PRIMARY KEY (kuvaId)
      );

      Huomaa, että tähän tauluun viittaus siihen uutiseen, johon kuva liittyy.

      • juha

        Kiitos vastauksestasi! kaikki muu meni jakeluun, mutta tuota viittausta en saanut toimimaan...
        Kuinka se pitäisi tehdä???


      • Keijo
        juha kirjoitti:

        Kiitos vastauksestasi! kaikki muu meni jakeluun, mutta tuota viittausta en saanut toimimaan...
        Kuinka se pitäisi tehdä???

        Se on niin sanottu "foreign key", eli viittausavain. Ilman sitäkin tuo tietokantarakenne toimii, mutta parempi nuo on aina laittaa tuollaisessa.

        Tuossa tapauksessa tuolla varmistaa että jokainen kuva on linkitetty johonkin uutiseen. Irrallista kuvaa ei voi kantaan laittaa koska tuon viittausavaimen kohde on löydyttävä tietokannasta.

        Eli sinun on ensin luotava uutinen, ja vasta sitten lisätä siihen liittyvät kuvat. Poistaessa sinun pitää poistaa ensin uutiseen liittyvät kuvat, sitten vasta itse uutinen.

        En ole mysql-guru mutta tämä syntaksi taitaa ollä lähempänä oikeaa:

        CREATE TABLE kuva (
        kuvaId INT NOT NULL AUTO_INCREMENT,
        kuva_uutinenId INT,
        kuvaTiedostonimi varchar(250) NOT NULL,
        PRIMARY KEY (kuvaId)
        FOREIGN KEY (kuva_uutinenId) REFERENCES (uutinen.uutinenId)
        );

        syntaksia ja tietoa:
        http://dev.mysql.com/doc/mysql/en/InnoDB_foreign_key_constraints.html


      • Koodari

        Itse tosin poistaisin noitten rivien nimestä uutinen, koska turhaa toistoa. Sekä kannattaa määritellä indexi nopeuttaa, varsinkin jos tekee jonkun haun jne...

        *timestampin tilalle voi ajatella jotain muutakin tekstiä.**

        Päivämäärä aina tietokannan omassa muodossa, timestamp on tässä tapauksessa parhain, kun sille tulee automaattisesti arvo, kun uutinen lisätään, tosin jos uutista muokataa, niin päivämäärä muuttuu senhetkises, joten kenties datetime olis kuitenkin parempa, riippuu miten halutaan tapahtuvan uutisten muokkaamises.


        Tohon kannattaa tehdä viel kolmaskin taulu jossa on uutistenlisääjät ja salasanat jne...

        Myslihän ei tuo kuin InnoDB tyyppisissä taulukoissa noita viiteavaimia, joten taulun tyyppi pitää määritellä, sekä itse määrittelisin ton viiteavaimen niin, jos uutinen poistetaan niin kuvan viittauksetkin poistetaan.


      • Keijo kirjoitti:

        Se on niin sanottu "foreign key", eli viittausavain. Ilman sitäkin tuo tietokantarakenne toimii, mutta parempi nuo on aina laittaa tuollaisessa.

        Tuossa tapauksessa tuolla varmistaa että jokainen kuva on linkitetty johonkin uutiseen. Irrallista kuvaa ei voi kantaan laittaa koska tuon viittausavaimen kohde on löydyttävä tietokannasta.

        Eli sinun on ensin luotava uutinen, ja vasta sitten lisätä siihen liittyvät kuvat. Poistaessa sinun pitää poistaa ensin uutiseen liittyvät kuvat, sitten vasta itse uutinen.

        En ole mysql-guru mutta tämä syntaksi taitaa ollä lähempänä oikeaa:

        CREATE TABLE kuva (
        kuvaId INT NOT NULL AUTO_INCREMENT,
        kuva_uutinenId INT,
        kuvaTiedostonimi varchar(250) NOT NULL,
        PRIMARY KEY (kuvaId)
        FOREIGN KEY (kuva_uutinenId) REFERENCES (uutinen.uutinenId)
        );

        syntaksia ja tietoa:
        http://dev.mysql.com/doc/mysql/en/InnoDB_foreign_key_constraints.html

        Pidemmällä tähtäimellä kuvista kannattaisi luoda oma tietokantansa tai vähintäänkin oma linkitettavä taulukko, jota voi käyttää muutkin kuin uutissovellus. Silloin pakolliset viittaukset uutistauluun pitäisi poistaa.

        No, tämä nyt on tätä newerending viilailua, mutta kuitenkin... vakavasti sovellusta rakennettaessa tällaiset mahdollisuudet huomioidaan mahdollisimman aikaisessa vaiheessa.

        Eka kertaa kantaa rakentavan olisi hyvä saada ensin reilusti aikaa harjoitteluun ja huolelliseen suunnitteluun. sittenhän se on jo melkein valmis. Hätäisesti tehty ja käyttöönotettu ei valmistu koskaan. Paitsi sitten, kun sitä ei enää käytetä.


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

    Luetuimmat keskustelut

    1. Räppäri kuoli vankilassa

      Ei kuulemma ole tapahtunut rikosta. Sama vahinkohan kävi Epsteinille. https://www.hs.fi/suomi/art-2000011840869.html "
      Maailman menoa
      98
      4466
    2. Välillä kyllä tuntuu, että jaat vihjeitä

      Mutta miten niistä voi olla ollenkaan varma? Ja minä saan niistä kimmokkeen luulemaan yhtä sun toista. Eli mitä ajatella
      Ikävä
      29
      3313
    3. No kyllä te luuserit voitte tehdä mitä vaan keskenänne, sitä en ymmärrä miksi pelaat,nainen

      Pisteesi silmissäni, edes ystävätasolla tippui jo tuhannella, kun sain selville pelailusi, olet toisen kanssa, vaikka ol
      Ikävä
      45
      2370
    4. Missä näitte viimeksi?

      Missä näit kaivattua viimeksi ja oliko sähköä ilmassa?
      Ikävä
      35
      1378
    5. Minulla on käsitys

      Ettet ole kovin se k s uaalinen ihminen.
      Ikävä
      34
      1143
    6. Harmittaako sinua yhtään?

      Tuntuuko pahalta ollenkaan?
      Ikävä
      37
      1086
    7. Puukotus yöllä

      Oli kaveri hermostunut ja antanut puukosta.
      Sotkamo
      13
      1054
    8. 158
      1007
    9. rakas J siellä jossain

      Niin ikävä sua. -P. Nainen
      Ikävä
      6
      934
    10. Masan touhut etenee

      Punatiilitalon tietotoimiston mukaan Masa on saanut viimein myytyä kämppänsä ja kaavoittaa uudelle lukaalille tonttia pa
      Äänekoski
      12
      872
    Aihe