Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php] Błąd w zapytaniu
Forum PHP.pl > Forum > Przedszkole
robert-0627
Wszystko działa takj jak chciałem ale mam pytanie czy w tym kodzie jest wszystko ok ?
  1. <?php
  2.  
  3. function dodaj($id, $nick, $tresc){
  4.  
  5. /*sprawdzenie poprawości przekazanych danych*/
  6.  
  7. if($nick == ''){
  8. echo("Brak danych. Proszę wypełnić pole: Imię i nazwisko.");
  9. return;
  10. }
  11.  
  12. if($tresc == ''){
  13. echo("Brak danych. Proszę wypełnić pole: Imię i nazwisko.");
  14. return;
  15. }
  16. if($id == '') $id = 'NULL';
  17.  
  18.  
  19. /*Nawiązanie połączenia z bazą*/
  20.  
  21. if (!$db_lnk = @mysql_connect("mysql3.yoyo.pl", "db486994", "xxxxxxxx")){
  22. echo('Wystąpił błąd podczas próby połączenia z serwerem MySQL...<BR>');
  23. return;
  24. }
  25.  
  26. if(!@mysql_select_db('db486994')){
  27. echo('Wystąpił błąd podczas wyboru bazy danych: biblioteka<BR>');
  28. return;
  29. }
  30.  
  31. /*Utworzenie i wykonanie zapytania*/
  32.  
  33. $query = "INSERT INTO shoutbox VALUES(";
  34. $query .= "'$id', '$nick', '$tresc'";
  35. $query .= ")";
  36.  
  37. if(!mysql_query($query, $db_lnk)){
  38. echo 'Wystąpił błąd: zapytanie zostało odrzucone...<br />Zapytanie: <pre>' . $query . '</pre>Odpowiedź MySQL: <pre>' . mysql_error( $db_lnk ) . '</pre>';
  39. return;
  40. }
  41.  
  42. /*Pobranie informacji o liczbie wstawionych wierszy*/
  43.  
  44. $rowsNo = mysql_affected_rows($db_lnk);
  45.  
  46. echo("Zapytanie zostało wykonane.<br>");
  47. echo("Liczba dodanych rekordów: $rowsNo<br>");
  48.  
  49. /*Zamknięcie połączenia z bazą*/
  50.  
  51. if(!@mysql_close()){
  52. echo('Wystąpił błąd podczas zamykania połączenia z serwerem MySQL...<br>');
  53. }
  54. }
  55.  
  56. if(isSet($_GET['nick']) && isSet($_GET['tresc'])){
  57. dodaj($_GET['$id'], $_GET['nick'], $_GET['tresc']);
  58. }
  59. else{
  60. echo("Niepoprawne dane!");
  61. }
  62.  
  63. ?>

Oraz do czego sluży ten fragment kodu?
  1. <?php
  2. if($id == '') $id = 'NULL';
  3. ?>
help_mee
gdzie masz definicje:
$db_lnk
robert-0627
A gdzie to powinenem wstawic?
Kicok
Zamień sobie:
  1. <?php
  2.  
  3. echo('Wystąpił błąd: zapytanie zostało odrzucone...<BR>');
  4.  
  5. ?>


na:
  1. <?php
  2.  
  3. echo 'Wystąpił błąd: zapytanie zostało odrzucone...<br />Zapytanie: <pre>' . $query . '</pre>Odpowiedź MySQL: <pre>' . mysql_error( $db_lnk ) . '</pre>';
  4.  
  5. ?>



A potem już tylko wyciągnięcie istotnych rzeczy z komunikatu błędu który Ci się pojawi i wklejenie tego na google.pl

Ja błąd widzę już teraz, ale dobrze będzie, jak się sam trochę pomęczysz ;]
robert-0627
Czy to o ten błąd chodzi ? : Column count doesn't match value count at row 1
pyro
tak o ten, liczby kolumn się nie zgadzaja

w tabeli shoutbox max wiecej lub mniej kolumn niz powinno byc
robert-0627
Zrobilem cos takiego . Wszystko działa . Ale mam pytanie czy w kodzie wszystko jest mniej więcej ok .

<?php

function dodaj($id, $nick, $tresc){

/*sprawdzenie poprawości przekazanych danych*/

if($nick == ''){
echo("Brak danych. Proszę wypełnić pole: Imię i nazwisko.");
return;
}

if($tresc == ''){
echo("Brak danych. Proszę wypełnić pole: Imię i nazwisko.");
return;
}
if($id == '') $id = 'NULL';


/*Nawiązanie połączenia z bazą*/

if (!$db_lnk = @mysql_connect("mysql3.yoyo.pl", "db486994", "kalarepa")){
echo('Wystąpił błąd podczas próby połączenia z serwerem MySQL...<BR>');
return;
}

if(!@mysql_select_db('db486994')){
echo('Wystąpił błąd podczas wyboru bazy danych: biblioteka<BR>');
@mysql_close();
return;
}

/*Utworzenie i wykonanie zapytania*/

$query = "INSERT INTO shoutbox VALUES(";
$query .= "'$id', '$nick', '$tresc'";
$query .= ")";

if(!mysql_query($query, $db_lnk)){
echo 'Wystąpił błąd: zapytanie zostało odrzucone...<br />Zapytanie: <pre>' . $query . '</pre>Odpowiedź MySQL: <pre>' . mysql_error( $db_lnk ) . '</pre>';
@mysql_close();
return;
}

/*Pobranie informacji o liczbie wstawionych wierszy*/

$rowsNo = mysql_affected_rows($db_lnk);

echo("Zapytanie zostało wykonane.<br>");
echo("Liczba dodanych rekordów: $rowsNo<br>");

/*Zamknięcie połączenia z bazą*/

if(!@mysql_close()){
echo('Wystąpił błąd podczas zamykania połączenia z serwerem MySQL...<br>');
}
}

if(isSet($_GET['nick']) && isSet($_GET['tresc'])){
dodaj($_GET['$id'], $_GET['nick'], $_GET['tresc']);
}
else{
echo("Niepoprawne dane!");
}

?>
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.