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ä :)
taas mysql-ongelma
12
476
Vastaukset
- 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
Petteri Orpo on satusetä
Väittää että työllisyys on Suomessa samalla tasolla kuin hallituksen aloittaessa kesällä 2023. Fakta on, että työllisi933504Orpo 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ä562478Porvarimedia: Räsänen vei Lindtmanilta pääministerin paikan
Lisäksi suomalaiset ovat innostuneet tuhlaaman, koska kuluttavat inflaation verran enemmän rahaa. Eikö porvarimedialla142384Jääkiekon MM:t pitää siirtää MTV:ltä Ylelle
Persuille ikäviä uutisia taas. . Valtioneuvoston asetuksen mukaan MM-kisat kuuluvat kansallisesti merkittäviin tapahtumi632244Ruotsi laskee jälleen bensaveroa, Riikka irvailee tumput suorana
Euron bensa oli persujen vaalilupaus, mutta kohta alkaa olla kolmosella alkavia litrahintoja. Meanwhile in Sverige: "162128Olitkin liian hyvää ollaksesi totta nainen
Ihastuin ja rakastuin, mutta se on minun ongelma. Ei sinun.771111Kaste pelastaa ihmisen
Kristittyjen kirkkojen toimittama yksi Kaste on Jumalan tekemä pelastusteko, jossa perisyntiin hengellisesti kuollut ihm5671077Ensin oli armo - sen jälkeen tuli usko
Me emme ansaitse armoa omalla uskollamme. Armo on ansaitsematonta rakkautta mikä synnyttää meidät uudesti Jumalasta. K400995Uskon todistus
Oikean uskovaisen ja nimikristityn erottaa siitä, että Jeesukseen uskova korottaa Jeesusta ja uskoa Häneen, mutta nimik261986Elisalla 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/digitoday142939