Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP] Zmienne w Smarty przy użyciu pętli while otrzymują złe wartości
Forum PHP.pl > Forum > Przedszkole
Darekxp
Witam! Tworzę wykres statystyk, przy użyciu Google Chart. Problem pojawił się, podczas pobierania rekordów z bazy z wykorzystaniem Smarty. Zmienne all i unique w szablonie otrzymują, jakby wartość z ostatniej pozycji pętli. Sprawdziłem podobny kod na samym php, bez Smarty i jest ok. Czy w Smarty potrzebuję np pętli w pętli, żeby zmienne all i unique miały prawidłowe wartości? Jak to rozwiązać? Za pomoc z góry dziękuję.

Działający kod php, bez Smarty:

  1. <?php
  2. $queryStats2 = mysql_query(' SELECT DISTINCT advertisingStatsDate FROM `advertising_stats` WHERE advertisingStatsAdvertisingId="2" ORDER by advertisingStatsDate ASC ');
  3. while($row2 = mysql_fetch_array($queryStats2))
  4. {
  5. $all = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsId FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  6. $unique = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsIP FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  7.  
  8. echo "['".$row2['advertisingStatsDate']."', $all, $unique], ";
  9. }
  10. ?>


Kod php z wykorzystaniem Smarty:

  1.  
  2. <?php
  3. $queryStats2 = mysql_query(' SELECT DISTINCT advertisingStatsDate FROM `advertising_stats` WHERE advertisingStatsAdvertisingId="'.$number.'" ORDER by advertisingStatsDate ASC ');
  4. while($row2 = mysql_fetch_array($queryStats2))
  5. {
  6. $stats2[] = $row2;
  7.  
  8. $all = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsId FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  9. $unique = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsIP FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  10.  
  11. $smarty -> assign('all', $all);
  12. $smarty -> assign('unique', $unique);
  13. }
  14.  
  15. $smarty -> assign('stats2', $stats2);
  16. ?>


Wycinek z szablonu:

  1. {section name="row2" loop="$stats2"}
  2. ['{$stats2[row2].advertisingStatsDate}', {$all}, {$unique}],
  3. {/section}
nospor
$smarty -> assign('all', $all);
$smarty -> assign('unique', $unique);
Przecież za każdym razem nadpisujesz zmienne to nic dziwnego ze otrzymujesz ostatni wynik. W czystym PHP ci to działało tylko dlatego, że od razu plułeś te dane na ekran.

Musisz to wszystko zapisać do tablicy, a dopiero tę tablicę przekazać do smarty i w smarty operować na tej tablicy
Darekxp
Można prosić o jakiś przykład?
rocktech.pl
Witam.

Możesz użyć metody append.

  1. <?php
  2. $smarty -> assign('all', array());
  3.  
  4. $smarty -> assign('unique', array());
  5. $queryStats2 = mysql_query(' SELECT DISTINCT advertisingStatsDate FROM `advertising_stats` WHERE advertisingStatsAdvertisingId="'.$number.'" ORDER by advertisingStatsDate ASC ');
  6.  
  7. while($row2 = mysql_fetch_array($queryStats2))
  8.  
  9. {
  10.  
  11. $stats2[] = $row2;
  12.  
  13.  
  14.  
  15. $all = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsId FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  16.  
  17. $unique = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsIP FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  18.  
  19.  
  20.  
  21. $smarty -> append('all', $all);
  22.  
  23. $smarty -> append('unique', $unique);
  24.  
  25. }
  26.  
  27.  
  28.  
  29. $smarty -> assign('stats2', $stats2);
  30.  
  31. ?>


A w szablonie daj sobie dodatkowo debug.

[SMARTY] pobierz, plaintext
  1. {section name="row2" loop="$stats2"}
  2.  
  3. ['{$stats2[row2].advertisingStatsDate}', {$all}, {$unique}],
  4.  
[SMARTY] pobierz, plaintext
Darekxp
Chwilkę, przed Twoim postem zrobiłem to w taki sposób, jak poniżej i jest ok. Pytanie, który sposób jest poprawniejszy/wydajniejszy ?

  1. {section name="row2" loop="$stats2"}
  2. ['{$stats2[row2].advertisingStatsDate}', {$all[$stats2[row2].advertisingStatsDate]}, {$unique[$stats2[row2].advertisingStatsDate]}],
  3. {/section}


  1. $queryStats2 = mysql_query(' SELECT DISTINCT advertisingStatsDate FROM `advertising_stats` WHERE advertisingStatsAdvertisingId="'.$number.'" ORDER by advertisingStatsDate ASC ');
  2. while($row2 = mysql_fetch_array($queryStats2))
  3. {
  4. $stats2[] = $row2;
  5.  
  6. $all[$row2['advertisingStatsDate']] = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsId FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  7. $smarty -> assign('all', $all);
  8.  
  9. $unique[$row2['advertisingStatsDate']] = mysql_num_rows(mysql_query('SELECT DISTINCT advertisingStatsIP FROM `advertising_stats` WHERE advertisingStatsDate="'.$row2['advertisingStatsDate'].'" '));
  10. $smarty -> assign('unique', $unique);
  11. }
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.