Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php] problem z mysql_fetch_array
Forum PHP.pl > Forum > Przedszkole
colinQ
Mam kod, powinno gdy znajdzie rekord nierówny $data to napisac nowy a gdy znajdzie równy $data to dopisac do pola all cyfrę o 1 wyzsza od poprzedniaj a nie zapisuje czemu?? blinksmiley.gif


  1. <?php
  2.  
  3. include("mysql.php");
  4.  
  5. // sprawdzenie IP
  6. function IP_prawdziwe(){
  7.  
  8. if ($_SERVER['HTTP_X_FORWARDED_FOR']) {
  9. $ip_prawdziwe = $_SERVER['HTTP_X_FORWARDED_FOR'];
  10. }
  11. else {
  12. $ip_prawdziwe = $_SERVER['REMOTE_ADDR'];
  13. }
  14.  
  15. return $ip_prawdziwe;
  16. }
  17.  
  18. ?>
  19.  
  20. <?
  21.  
  22. $ip = $_SERVER['REMOTE_ADDR'];
  23. $data = date("dmY");
  24. $wyszukaj_z_ip = mysql_query("select * from statystyki where ip='$ip'"); 
  25. $fetch_z_ip = mysql_fetch_assoc($wyszukaj_z_ip);
  26. $ile_z_ip = mysql_num_rows($wyszukaj_z_ip);
  27.  
  28. $all = mysql_num_rows(mysql_query("select * from statystyki"));
  29. $dzis = mysql_num_rows(mysql_query("select * from statystyki where data='$data'"));
  30.  
  31. if($fetch_z_ip['data'] !== $data) {
  32. mysql_query("insert into statystyki values('$ip', '$data', '1')");
  33. }
  34. else {
  35. $twoje_unikalne = $fetch_z_ip['all'];
  36. $uniksy_do_zapisu = $twoje_unikalne + 1;
  37. echo $uniksy_do_zapisu;
  38. mysql_query("update statystyki set all='$uniksy_do_zapisu' where ip='$ip'");
  39. }
  40.  
  41. echo 'twoje => '.$ile_z_ip.'<br>';
  42. echo 'unikalne => '.$all.'<br>';
  43. echo 'dzis => '.$dzis.'<br>';
  44.  
  45.  
  46. ?>
mild
  1. <?php
  2. if($fetch_z_ip['data'] !== $data) {
  3. ?>


Po co !== ? Samo != powinno działać.
colinQ
Tamto już zrobiłem teraz się nowy błąd narodził dry.gif :

Warning:
mysql_fetch_array(): supplied argument is not a valid MySQL result resource in c:\usr\apache\httpd\html\homepage\stats.php on line 42

  1. <?php
  2.  
  3. include("mysql.php");
  4.  
  5. // sprawdzenie IP
  6. function IP_prawdziwe(){
  7.  
  8. if ($_SERVER['HTTP_X_FORWARDED_FOR']) {
  9. $ip_prawdziwe = $_SERVER['HTTP_X_FORWARDED_FOR'];
  10. }
  11. else {
  12. $ip_prawdziwe = $_SERVER['REMOTE_ADDR'];
  13. }
  14.  
  15. return $ip_prawdziwe;
  16. }
  17.  
  18. ?>
  19.  
  20. <?
  21.  
  22. $ip = $_SERVER['REMOTE_ADDR'];
  23. $data = date("dmY");
  24. $wyszukaj_z_ip = mysql_query("select * from statystyki where ip='$ip' && data='$data'"); 
  25. $fetch_z_ip = mysql_fetch_assoc($wyszukaj_z_ip);
  26. $ile_z_ip = mysql_num_rows($wyszukaj_z_ip);
  27.  
  28.  
  29. if($ile_z_ip > 0) {
  30. $twoje_unikalne = $fetch_z_ip['all'];
  31. $uniksy_do_zapisu = $twoje_unikalne + 1;
  32. mysql_query("UPDATE `statystyki` SET `all` = '$uniksy_do_zapisu' WHERE `ip` = '$ip' AND `data` = '$data' AND `all` = '$twoje_unikalne' LIMIT 1 ;");
  33. }
  34. else {
  35. mysql_query("insert into statystyki values('$ip', '$data', '1')");
  36. }
  37.  
  38. $all = mysql_num_rows(mysql_query("select * from statystyki"));
  39. $dzis = mysql_num_rows(mysql_query("select * from statystyki where data='$data'"));
  40.  
  41. $aaaa = mysql_query("select all from statystyki");
  42. $wszystkie = 0;
  43.  
  44. for($i=1; $i<=$all; $i++) {
  45. $b = mysql_fetch_array($aaaa);
  46. $wszystkie = $wszystkie + $b[0];
  47.  
  48. }
  49.  
  50. echo 'twoje => '.$ile_z_ip.'<br>';
  51. echo 'unikalne => '.$all.'<br>';
  52. echo 'dzis => '.$dzis.'<br>';
  53. echo 'odslon => '.$wszystkie.'<br>';
  54.  
  55.  
  56. ?>
Cienki1980
Masz kolumnę 'all' w tabeli statystyki questionmark.gif Błąd się generuje, bo masz złe zapytanie do bazy. Sprawdź czy na pewno zapytanie jest poprawne.
colinQ
Mam kolumnę all, a zapytanie jest raczej dobre bo kilka linijek wyżej jest to samo (podobne).
mild
$b = mysql_fetch_array($aaaa);
Nie ma sensu umieszczać tego w pętli. Przerzuć to przed for.
W linii 32 masz zapytanie, zmienne uniksy_do_zapisu i twoje_unikalne nie musza być w ' ', skoro to liczby.
Poza tym, łatwiej w zapytaniu skorzystać z funkcji mysql SUM(), żeby otrzymać sumę wszystkich rekordów. Tak jest wygodniej niż wykorzystywać do tego pętlę...
colinQ
Cytat(mild @ 16.09.2007, 14:26:06 ) *
$b = mysql_fetch_array($aaaa);
Nie ma sensu umieszczać tego w pętli. Przerzuć to przed for.


Jest bo po odczytaniu w każdym rekordzie pola all ma jego wartość dodać do zmiennej wszystko. winksmiley.jpg

Cytat
Poza tym, łatwiej w zapytaniu skorzystać z funkcji mysql SUM(), żeby otrzymać sumę wszystkich rekordów. Tak jest wygodniej niż wykorzystywać do tego pętlę...


Odpowiedź jest wyżej...
Cienki1980
Cytat(colinQ @ 16.09.2007, 15:06:09 ) *
Jest bo po odczytaniu w każdym rekordzie pola all ma jego wartość dodać do zmiennej wszystko. winksmiley.jpg
Odpowiedź jest wyżej...

No to może powiesz mi jaka jest różnica w kodzie :
  1. <?php
  2. $query=mysql_query("select sum(all) as suma from statystyki");
  3. $row=mysql_fetch_array($query);
  4. echo $row['suma'];
  5. ?>

a kodem
  1. <?php
  2. $query=mysql_query("select all from statystyki");
  3. $wszystko=0;
  4. //korzystam z while , ale to bez różnicy .. no może poza tą, że nie muszę odpytywa
    ć bazy o ilość rekordów
  5. //bądź też używać count();
  6. while($row=mysql_fetch_array($query))
  7.  $wszystko+=$row['all'];
  8.  
  9. echo $wszystko;
  10. ?>



A co do błędu jak dla mnie to ta część kodu gdzie jest mysql_fetch_array() jest poprawna ... pokaż dokładnie która to jest linijka numer 42 w pliku stats.php
soomal
Cytat(Cienki1980 @ 16.09.2007, 16:41:13 ) *
No to może powiesz mi jaka jest różnica w kodzie :
  1. <?php
  2. $query=mysql_query("select sum(all) as suma from statystyki");
  3. $row=mysql_fetch_array($query);
  4. echo $row['suma'];
  5. ?>

a kodem
  1. <?php
  2. $query=mysql_query("select all from statystyki");
  3. $wszystko=0;
  4. //korzystam z while , ale to bez różnicy .. no może poza tą, że nie muszę odpytywa
  5.  bazy o ilość rekordów
  6. //bądź też używać count();
  7. while($row=mysql_fetch_array($query))
  8.  $wszystko+=$row['all'];
  9.  
  10. echo $wszystko;
  11. ?>


Jaka różnica?
1. wersja jest bardziej elegancka i szybsza.
colinQ
Ni niestety to nie pomogło... :/
mild
Zamien zapytanie na
$aaaa = mysql_query("select all from statystyki") or die(mysql_error());

Albo wrzuc w phpmyadminie, musi zwracac jakis blad.
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.