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 = 'osoite@osoite.com', 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

481

    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. Ukrainan ulkoministeri: Moskova aistii tappion Ukrainassa

      Dmytro Kuleban mukaan Venäjä yrittää puheillaan pelotella länsimaita. Ukrainan ulkoministerin Dmytro Kuleban mukaan Venäjän esittämät varoitukset kol
      NATO
      262
      4320
    2. Stefu haikailee

      Julkaisi stooreissa kuvan vickestä. Sitten Martinasta treenaamassa Hangossa ulkona. Hmm.
      Kotimaiset julkkisjuorut
      265
      3524
    3. Harmi mies ettet arvostanut

      Minua tarpeeksi. Myöhemmin kaikki olisi palkittu ja olisin antanut sinulle aitoa rakkautta. Tämä sattuu mutta yritän ajatella, että ehkä se rakkaus ku
      Ikävä
      157
      1841
    4. Oi! Legandaarinen Vesa-Matti "Vesku" Loiri, 77, poseeraa kahdessa eri kuvassa - Some riemastui!

      Vesa-Matti "Vesku" Loiri on kyllä legenda jo eläessään. Hienoa nähdä, että virtaa piisaa. Voimia, iloa ja eloa, Vesku! https://www.suomi24.fi/viihde
      Suomalaiset julkkikset
      25
      1726
    5. Lavrov väläyttelee WW3:sta

      Venäjän ulkoministeri Sergei Lavrov varoittaa, että kolmannen maailmansodan uhka on todellinen. Lavrov sanoi venäläiselle uutistoimisto Interfaxille,
      Maailman menoa
      299
      1452
    6. Ketä Sofia fanit veikkaatte seuraavaksi lompakoksi?

      Kenestä Sofia höynäyttää itselleen seuraavan lompakon?
      Kotimaiset julkkisjuorut
      133
      974
    7. Suomi24 kysely: ihmisten kuplautumista ei pääosin koeta vakavaksi ongelmaksi

      “Kuplautumista on mahdotonta estää. Ihmiset ovat aina viihtyneet samankaltaiset arvot ja maailmankatsomuksen jakavassa seurassa ja muodostaneet sen pe
      Suomi24 Blogi ★
      18
      879
    8. Voiko hyvää omatuntoa ostaa?

      Olen tässä nyt muutaman päivän paininut erään rahaan liittyvän pulman kanssa. Kerron ensin vähän taustaa ... Eli erosin 15 vuoden parisuhteesta 9 vuo
      Sinkut
      235
      866
    9. en vaan saa häntä pois

      Mielestäni pyörimästä. Onko kellekään toiselle käynyt näin? Ihastuin pakkomielteisesti noin vuosi sitten erääseen naiseen. Ei vaan katoa mielestä va
      Ikävä
      115
      858
    Aihe