taas mysql-ongelma

missä_Vika?

Eli minulla on sivulla lomake joka hakee tietokannasta tiedot ja sitten noita tietoja pystyy siinä muokkaamaan. Koodin pätkä on seuraavanlainen:


mysql_select_db($database,$yhteys) or die("Virhe valittaessa tietokantaa!");

mysql_connect($server, $user, $pass) or die("Virhe kytkettäessä tietokantaan!");

$query = "UPDATE asiakkaat SET yritys = '$company', etunimi = '$fname', sukunimi = '$sname', kosoite = '$address', postinro = $address1, postitp = '$address2', kosoite2 = '$address3', postinro2 = $address4, postitp2 = '$address5', puhelin = '$phone', email = '$email', tiedot = '$brief', huomautettavaa = '$notice', tyyppi = $tyyppi, hintar = $hintar, riski = $riski, maksut = $maksut WHERE id = $clientid";

mysql_query($query) or die('Virhe suoritettaessa komentoa'.$query);

Saan kuitenkin seuraavanlaisen virheilmoituksen:

Virhe suoritettaessa komentoa
UPDATE asiakkaat SET yritys = 'Kesko Oy', etunimi = 'Pauli', sukunimi = 'Paulinen', kosoite = 'Katu 4', postinro = 45456, postitp = 'Helsinki', kosoite2 = 'katujenkatu 4', postinro2 = 45454, postitp2 = 'Espoo', puhelin = '09-646464', email = '[email protected]', tiedot = 'Huono maksamaan', huomautettavaa = 'Maksamattomia laskuja', tyyppi = 4, hintar = 2, riski = 1, maksut = 1 WHERE id = 44

Nuo taulun kenttien nimet olen tarkistanut ja ne ovat oikein. Lisäksi lisäilin hipsuja ja kokeilin poistaa niitä, mutta sillä ei tunnu olevan vaikutusta. Mikä tuossa oikein voisi olla vikana? Itsellä ei enää taidot riitä :)

12

476

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Nimimerkki

      Jos ajat tuon käskyn suoraan tietokantaan mysqladminilla tms, meneekö käsky läpi vai saatko jonkun herjan...? Voit rajata virheen aiheuttajaa, onko ongelma php-koodissa vai sql-lauseessa.

      • missä_Vika?

        Joo kyllä tuo käsky näytti läpi menevän eli vika siis PHP:ssä. Ainoa ongelma on ettei ole mitään hajua mistä alkaisi tuota virhettä metsästämään... ideoita?


    • Olla näin

      Mikä on tuo $yhteys -muutuja? Pitäisikö sen olla näin:
      $yhteys = mysql_connect($server, $user, $pass) or die("Virhe kytkettäessä tietokantaan!");
      mysql_select_db($database,$yhteys) or die("Virhe valittaessa tietokantaa!");

      • missä_Vika?

        Joo, noin se onkin unohdin vain tuon $yhteys-muuttujan pois viestistä.

        itseasiassa rivi:

        mysql_query($query) or die('Virhe suoritettaessa komentoa'.$query);

        oli alunperin mysql_query($query, $yhteys), mutta tässä on pitänyt kokeilla kaikkea jotta saisi tuon toimimaan :) Eli otin tuon $yhteys muuttujan tuosta pois ja laitoin rivin joka yhdistää tietokantaan. Mutta ei silti äly riitä keksimään, missä vika on :(

           


      • teuro
        missä_Vika? kirjoitti:

        Joo, noin se onkin unohdin vain tuon $yhteys-muuttujan pois viestistä.

        itseasiassa rivi:

        mysql_query($query) or die('Virhe suoritettaessa komentoa'.$query);

        oli alunperin mysql_query($query, $yhteys), mutta tässä on pitänyt kokeilla kaikkea jotta saisi tuon toimimaan :) Eli otin tuon $yhteys muuttujan tuosta pois ja laitoin rivin joka yhdistää tietokantaan. Mutta ei silti äly riitä keksimään, missä vika on :(

           

        laita vielä että
        $yhteys = mysql_connect("****", "****", "****");
        $tietokanta = mysql_select_db("****", $yhteys);


        Ja sitten kyselyä perään.


      • missä_Vika?
        teuro kirjoitti:

        laita vielä että
        $yhteys = mysql_connect("****", "****", "****");
        $tietokanta = mysql_select_db("****", $yhteys);


        Ja sitten kyselyä perään.

        Eipä tunnu auttavan mikään. Tämä on siis tämän hetkinen koodi:

        $yhteys = mysql_connect($server, $user, $pass) or die("Virhe kytkettäessä tietokantaan!");
        mysql_select_db($database,$yhteys) or die("Virhe valittaessa tietokantaa!");

        if($clientid != null) {

        $query = "UPDATE asiakkaat SET yritys = '$company', etunimi = '$fname', sukunimi = '$sname', kosoite = '$address', postinro = $address1, postitp = '$address2', kosoite2 = '$address3', postinro2 = $address4, postitp2 = '$address5', puhelin = '$phone', email = '$email', tiedot = '$brief', huomautettavaa = '$notice', tyyppi = $tyyppi, hintar = $hintar, riski = $riski, maksut = $maksut WHERE id = $clientid";
        mysql_query($query,$yhteys) or die('Virhe suoritettaessa komentoa'.$query);
        $last_client_id = previous_id("asiakkaat", "id");


        }

        else{

        $query = "INSERT INTO asiakkaat (yritys, etunimi, sukunimi, kosoite, postinro, postitp, kosoite2, postinro2, postitp2, puhelin, email, tiedot, huomautettavaa, hintar, tyyppi, riski, maksut ) VALUES ( '".$company."', '".$fname."', '".$sname."', '".$address."', '".$address1."','".$address2."','".$address3."','".$address4."','".$address5."','".$phone."', '".$email."', '".$brief."', '".$notice."','".$hintar."','".$tyyppi."','".$riski."','".$maksut."')";
        mysql_query($query,$yhteys) or die('Virhe suoritettaessa komentoa'.$query);
        $last_client_id = previous_id("asiakkaat", "id");


        }

        mysql_close($yhteys);


        Tuo Else-lauseen INSERT INTO toimii täydellisesti, joten en ymmärrä missä tuossa UPDATE:ssa olisi niin paljon eroa että se aiheuttaisi tuon virheen...


    • kerran.

      Virhetilanteissa pähkäilyn sijasta kannattaa käyttää koneen omaa virhejäljitystä kun se on kerta ihan sitä varten tehty.

      Lisää siis siihen die-haaraan mysql_errno($link) ja mysql_error($link) tai katso niiden tulokset echo:lla.

    • frtr

      ...
      mysql_query($query);

      echo mysql_errno($yhteys) . ": " . mysql_error($yhteys) . "\n";


      Niin näät mitä erroreita tietokanta palauttaa.

      • missä_Vika?

        Tällaiset virheilmoitukset sain noilla metodeilla:

        Warning: mysql_query(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 109

        Warning: mysql_errno(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 111

        Warning: mysql_error(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 111
        :
        Warning: mysql_close(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 124


        Tässä vielä rivit 106-124:
        if($clientid != null) {

        $query = "UPDATE asiakkaat SET yritys = '$company', etunimi = '$fname', sukunimi = '$sname', kosoite = '$address', postinro = $address1, postitp = '$address2', kosoite2 = '$address3', postinro2 = $address4, postitp2 = '$address5', puhelin = '$phone', email = '$email', tiedot = '$brief', huomautettavaa = '$notice', tyyppi = $tyyppi, hintar = $hintar, riski = $riski, maksut = $maksut WHERE id = $clientid";
        mysql_query($query,$yhteys);// or die(mysql_errno($yhteys));
        //$last_client_id = previous_id("asiakkaat", "id");
        echo mysql_errno($yhteys) . ": " . mysql_error($yhteys) . "\n";

        }

        else{

        $query = "INSERT INTO asiakkaat (yritys, etunimi, sukunimi, kosoite, postinro, postitp, kosoite2, postinro2, postitp2, puhelin, email, tiedot, huomautettavaa, hintar, tyyppi, riski, maksut ) VALUES ( '".$company."', '".$fname."', '".$sname."', '".$address."', '".$address1."','".$address2."','".$address3."','".$address4."','".$address5."','".$phone."', '".$email."', '".$brief."', '".$notice."','".$hintar."','".$tyyppi."','".$riski."','".$maksut."')";
        mysql_query($query,$yhteys) or die('Virhe suoritettaessa komentoa'.$query);
        $last_client_id = previous_id("asiakkaat", "id");


        }

        mysql_close($yhteys);


        Eli minkälaiseen ongelmaan nämä viittaavat ja miten ongelma korjaantuisi?


      • niin!
        missä_Vika? kirjoitti:

        Tällaiset virheilmoitukset sain noilla metodeilla:

        Warning: mysql_query(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 109

        Warning: mysql_errno(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 111

        Warning: mysql_error(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 111
        :
        Warning: mysql_close(): 2 is not a valid MySQL-Link resource in /var/www/vahvista2.php on line 124


        Tässä vielä rivit 106-124:
        if($clientid != null) {

        $query = "UPDATE asiakkaat SET yritys = '$company', etunimi = '$fname', sukunimi = '$sname', kosoite = '$address', postinro = $address1, postitp = '$address2', kosoite2 = '$address3', postinro2 = $address4, postitp2 = '$address5', puhelin = '$phone', email = '$email', tiedot = '$brief', huomautettavaa = '$notice', tyyppi = $tyyppi, hintar = $hintar, riski = $riski, maksut = $maksut WHERE id = $clientid";
        mysql_query($query,$yhteys);// or die(mysql_errno($yhteys));
        //$last_client_id = previous_id("asiakkaat", "id");
        echo mysql_errno($yhteys) . ": " . mysql_error($yhteys) . "\n";

        }

        else{

        $query = "INSERT INTO asiakkaat (yritys, etunimi, sukunimi, kosoite, postinro, postitp, kosoite2, postinro2, postitp2, puhelin, email, tiedot, huomautettavaa, hintar, tyyppi, riski, maksut ) VALUES ( '".$company."', '".$fname."', '".$sname."', '".$address."', '".$address1."','".$address2."','".$address3."','".$address4."','".$address5."','".$phone."', '".$email."', '".$brief."', '".$notice."','".$hintar."','".$tyyppi."','".$riski."','".$maksut."')";
        mysql_query($query,$yhteys) or die('Virhe suoritettaessa komentoa'.$query);
        $last_client_id = previous_id("asiakkaat", "id");


        }

        mysql_close($yhteys);


        Eli minkälaiseen ongelmaan nämä viittaavat ja miten ongelma korjaantuisi?

        >...minkälaiseen ongelmaan nämä viittaavat...

        Rivinumeroista ja virheilmoituksen sisällöstä voi päätellä että muuttujan $yhteys sisältö on jotenkin kuralla.


      • missä_Vika?
        niin! kirjoitti:

        >...minkälaiseen ongelmaan nämä viittaavat...

        Rivinumeroista ja virheilmoituksen sisällöstä voi päätellä että muuttujan $yhteys sisältö on jotenkin kuralla.

        $yhteys = mysql_connect($server, $user, $pass) or die("Virhe kytkettäessä tietokantaan!");

        No tuossa siis $yhteys-muuttujan sisältö, jonka jo aiemmissa posteissa mainitsinkin, mutta en vaan keksi mitä vikaa tuossa voi olla. Muualla kun kuitenkin tuolla samalla tavalla käytän tuota, kuten tuossa else lauseessa ja ilman ongelmia.. Eli voisiko ongelma olla jossain muualla, kuten php:n asetuksissa? Rasittava ongelma...


      • ilman.
        missä_Vika? kirjoitti:

        $yhteys = mysql_connect($server, $user, $pass) or die("Virhe kytkettäessä tietokantaan!");

        No tuossa siis $yhteys-muuttujan sisältö, jonka jo aiemmissa posteissa mainitsinkin, mutta en vaan keksi mitä vikaa tuossa voi olla. Muualla kun kuitenkin tuolla samalla tavalla käytän tuota, kuten tuossa else lauseessa ja ilman ongelmia.. Eli voisiko ongelma olla jossain muualla, kuten php:n asetuksissa? Rasittava ongelma...

        mysql_query():n link-parametri on optionaalinen. Jos sen jättää pois niin käytetään automaattisesti viimeistä mysql_connect():n palauttamaa arvoa.

        http://fi.php.net/mysql_query

        Kokeile siis näin:
        mysql_query($query) or die('Virhe suoritettaessa komentoa'.$query);


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

    Luetuimmat keskustelut

    1. Petteri Orpo on satusetä

      Väittää että työllisyys on Suomessa samalla tasolla kuin hallituksen aloittaessa kesällä 2023. Fakta on, että työllisi
      Maailman menoa
      93
      3504
    2. Orpo ja Purra, käykää hakemassa oppia Espanjasta

      Espanja on näyttänyt kuinka kova työttömyys nujerretaan ja saadaan maan talous palautettua nousu-uralle. Ei ole häpeä kä
      Maailman menoa
      56
      2478
    3. Porvarimedia: Räsänen vei Lindtmanilta pääministerin paikan

      Lisäksi suomalaiset ovat innostuneet tuhlaaman, koska kuluttavat inflaation verran enemmän rahaa. Eikö porvarimedialla
      Maailman menoa
      14
      2384
    4. Jääkiekon MM:t pitää siirtää MTV:ltä Ylelle

      Persuille ikäviä uutisia taas. . Valtioneuvoston asetuksen mukaan MM-kisat kuuluvat kansallisesti merkittäviin tapahtumi
      Maailman menoa
      63
      2244
    5. Ruotsi laskee jälleen bensaveroa, Riikka irvailee tumput suorana

      Euron bensa oli persujen vaalilupaus, mutta kohta alkaa olla kolmosella alkavia litrahintoja. Meanwhile in Sverige: "
      Maailman menoa
      16
      2128
    6. Olitkin liian hyvää ollaksesi totta nainen

      Ihastuin ja rakastuin, mutta se on minun ongelma. Ei sinun.
      Ikävä
      77
      1111
    7. Kaste pelastaa ihmisen

      Kristittyjen kirkkojen toimittama yksi Kaste on Jumalan tekemä pelastusteko, jossa perisyntiin hengellisesti kuollut ihm
      Kaste
      567
      1077
    8. Ensin oli armo - sen jälkeen tuli usko

      Me emme ansaitse armoa omalla uskollamme. Armo on ansaitsematonta rakkautta mikä synnyttää meidät uudesti Jumalasta. K
      Luterilaisuus
      400
      995
    9. Uskon todistus

      Oikean uskovaisen ja nimikristityn erottaa siitä, että Jeesukseen uskova korottaa Jeesusta ja uskoa Häneen, mutta nimik
      Kaste
      261
      986
    10. Elisalla ja MTV:llä lihava riita - MTV:n kanavienlähetykset ovat katkeamassa Elisan asiakkailla

      Kaikkien MTV:n kanavien televisiolähetykset ovat katkeamassa Elisan kaapeli-tv-asiakkailta. https://www.is.fi/digitoday
      Maailman menoa
      142
      939
    Aihe