PHP ja MySQL - INSERT INTO ongelmia

noobie

jeps. IHan alkuun pitää sanoa että olen totaalinen aloittelija PHP:n kanssa, oon koodannu enemmän ASP:illa (eli jotain käsitystä siitä mitä pitäisi tapahtua). Sain justiin asennettua serverille PHP:n ja MySQL:n (kun nyt piti sitten saada sivut tehtyä PHP:llä) ja tehtyä MySQL:ään tietokannan tietueineen.

Pitäis tehdä formi jolla vois submittaa tietokantaan, mutta kun koitan tuota mitä oon tehny niin MySQL:n admin sanoo ettei siellä ole yhtäkään riviä.

Tän verran oon nyt saanu pähkäiltyä:

8

1897

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • se ok, lisää hihnalla

      tuo äskönen ratkes kun laitoin kaikki tietueen palstat SQL:ään:

      tämän sijasta
      $SQL = "INSERT INTO news(iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES('$date','$time','$auth','$pic','$head','$text','$memo')";

      laitoin
      $SQL = "INSERT INTO news(ID,iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES('1','$date','$time','$auth','$pic','$head','$text','$memo')";

      Missä tuo ID on mediumint(8), not null, auto increment, unsigned. Ongelma on nyt siinä että se pitäisi saada se numero juoksemaan automaattisesti kun sinne tiatokantaan tyrkkää dataa, eikä niin että se muutetaan koodissa, vai onko se edes mahdollista? Eikös auto increment justiin tarkota sitä et se nostaa sitä automaagisesti? hmpf.. on tääkin.

      Elikkä, jos olis jotain ratkasua tuohon niin olis taas paljon viisaampi.. siis miten sais tuon nomeron juokseen... vai pitääkö se tosiaan ensin käydä lukemassa tietokannasta et mikä se on ja sit lisätä siihen yksi niin että se toimii? o.O

      • flap

        laita vaikka NULL

        $SQL = "INSERT INTO news(ID,iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES(NULL,'$date','$time','$auth','$pic','$head','$text','$memo')";


      • noobie
        flap kirjoitti:

        laita vaikka NULL

        $SQL = "INSERT INTO news(ID,iDate,iTime,iAuthor,iPic,iHeader,iText,iMemo) VALUES(NULL,'$date','$time','$auth','$pic','$head','$text','$memo')";

        kun siinä kuitenkin *pitäisi* olla se juokseva numero siellä tietokannassa....

        Ratkaisin sen kuitenkin jo toisella tavalla, eli ensin lukemalla jo olemassaolevan ja lisäämällä siihen yhden. ah, niin aataminaikaista.


      • mysli uuno
        noobie kirjoitti:

        kun siinä kuitenkin *pitäisi* olla se juokseva numero siellä tietokannassa....

        Ratkaisin sen kuitenkin jo toisella tavalla, eli ensin lukemalla jo olemassaolevan ja lisäämällä siihen yhden. ah, niin aataminaikaista.

        Yleensä tällaisissa tapauksissa luodaan sekvenssi ja annetaan id:lle oletusarvoksi sekvenssin seuraava merkki. Eikö tällainen onnistu mysql:ssä?

        Tuolla metodillasi, jossa luet, lasket ja kirjoitat saattaa tulla äkkiä ongelmia päällekkäisten kyselyjen takia. Itse asiassa päällekkäiset kyselyt taitavat rikkoa kantasi rakenteen heti.


      • flap
        noobie kirjoitti:

        kun siinä kuitenkin *pitäisi* olla se juokseva numero siellä tietokannassa....

        Ratkaisin sen kuitenkin jo toisella tavalla, eli ensin lukemalla jo olemassaolevan ja lisäämällä siihen yhden. ah, niin aataminaikaista.

        jos sulla on se id auto_increment niin kyllä se määrää sen arvon siihen automaagisesti jos laitat arvoksi null.. passaa kokeilla..


      • noobie
        flap kirjoitti:

        jos sulla on se id auto_increment niin kyllä se määrää sen arvon siihen automaagisesti jos laitat arvoksi null.. passaa kokeilla..

        Kiitos tuhannesti vinkistä, se toimi.

        Nyt mulla olis lisää ongelmia =P



        Tällanen koodinpätkä tällä kertaa:



                    if ($_POST['delete'] == "pass") {
                       $vID = $_POST['NewsID'];
                       ?>


      • noobie
        noobie kirjoitti:

        Kiitos tuhannesti vinkistä, se toimi.

        Nyt mulla olis lisää ongelmia =P



        Tällanen koodinpätkä tällä kertaa:



                    if ($_POST['delete'] == "pass") {
                       $vID = $_POST['NewsID'];
                       ?>

        Otin tähden pois SQL-lauseesta ja nyt se toimii.

        ennen
        $SQL = "DELETE * FROM news WHERE ID = '$vID'";

        jälkeen
        $SQL = "DELETE FROM news WHERE ID = '$vID'";


      • ---------
        noobie kirjoitti:

        Otin tähden pois SQL-lauseesta ja nyt se toimii.

        ennen
        $SQL = "DELETE * FROM news WHERE ID = '$vID'";

        jälkeen
        $SQL = "DELETE FROM news WHERE ID = '$vID'";

        Toimii noin, mutta missäs se tietoturva on?

        Laita syötteet http://fi.php.net/manual/en/function.mysql-real-escape-string.php läpi ellet muuten tarkasta niit.

        Mitähän tapahtuu jos $vID saakin tämmösen arvon ' AND ID > '0

        Poistetaan ID joka on tyhjä ja lisäksi kaikki joiden ID on suurempa kuin 0, siis kaikki.


        Ja vinkkinä, että kun includetat niin sen voi tehdä suoraan eikä tartte laittaa mitään ylimääräsiä

        Ja selvyyden vuoksi kannattaa kannattaisi tehdä hieman toisin tuo. Otat yhteyden tietokantaan ennen if/else juttuja ja suljet senjälkeen näin ei tartte tupla includeita.

        Lukaseppas http://keskustelu.suomi24.fi/show.fcgi?category=108&conference=500000000000005&posting=22000000016627783 varsinkin se viiminen linkki.


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

    Luetuimmat keskustelut

    1. Riikan kukkaronnyöri on umpisolmussa

      Kulutus ei lähde liikkeelle, koska kansalaiset eivät usko, että: – työpaikka säilyy – tulot eivät romahda – talous ei h
      Maailman menoa
      45
      2929
    2. Jos vedetään mutkat suoraksi?

      Niin kumpaan ryhmään kuulut? A) Niihin, jotka menevät edellä ja tekevät? Vai B) Niihin, jotka kulkevat perässä ja ar
      Sinkut
      106
      2701
    3. Tanskan malli perustuu korkeaan ansioturvaan

      Ja vahvoihin työllisyys- ja kotoutumispalveluihin. Suomessa Riikka on leikannut juuri näitä: palkkatukea, työttömyysturv
      Maailman menoa
      36
      2419
    4. Kuka paiskasi vauvan betoniin Oulussa?

      Nimi esiin.....
      Oulu
      32
      2014
    5. Vain vasemmistolaiset ovat aitoja suomalaisia

      Esimerkiksi persut ovat ulkomaalaisen pääomasijoittajan edunvalvojia, eivät auta köyhiä suomalaisia.
      Maailman menoa
      50
      1918
    6. Anteeksipyyntöni

      Jätän tähän anteeksipyyntöni sinulle, koska en voi sanoa sitä missään muuallakaan. Pyydän anteeksi, jos purkamani tuska
      Järki ja tunteet
      15
      1529
    7. Miten must tuntuu

      et sä ajattelet mua just nyt
      Ikävä
      32
      1473
    8. Sydämeni valtiaalle

      En täältä aio asioita kysellä. Haluan tuoda tiedoksesi, että pohjimmiltani en ihmisiä tahdo satuttaa ja ajattelen muiden
      Ikävä
      105
      1225
    9. Kun et vain tajua että

      sua lähestytään feikkiprofiililla :D Hanki aivot :D m-n
      Ikävä
      177
      1193
    10. En vain unohda

      Sitä miten rakastuneesti olet minua katsonut. Oliko tunteet liian suuria että niistä olisi voinut puhua.
      Ikävä
      73
      1050
    Aihe