Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Odczytywanie cachy (serialize)
Forum PHP.pl > Forum > Przedszkole
Moli
Hej

Mam pewien, zdaje się że dość prosty problem, ale nie wiem jak najlepiej go rozwiązać. Cachuje wpisy z bazy za pomocą serialize i zapisuje do pliku, następnie odserializowuje i chce przy pomocy pętli while (tej samej która czyta tablice z pierwszego pobrania z bazy, w razie braku cachu) wyświetlić wpisy z bazy.

Tablica bez cachowania wygląda tak
Kod
Array ( [id] => 1 [text] => cos )

a po scachowaniu tak
Kod
Array ( [0] => Array ( [id] => 1 [text] => cos ) )


Jaki jest najlepszy i najszybszy (w końcu to cache) na odczytanie cache?
mike
Pokaż kod. Na pewno robisz błąd.
Jasnowdzó tu nie ma.

I popraw tytuł wątku inaczej go zamknę.
Moli
Do przekazywania parametrów jest metoda (odchudzona teraz)
  1. <?php
  2. public function sqlParm ()
  3. {
  4. if ( $this->cacheStatus == 1 ) 
  5. {
  6. $this->array = unserialize ( file_get_contents ( $this->cacheFile ) ) ;
  7.  
  8. return $this->array ;
  9. }
  10. else
  11. {
  12.  $this->array = mysql_fetch_array ( $this->sqlQuery , MYSQL_ASSOC ) ;
  13.  
  14.  while ( $row = $this->array )
  15.  {
  16. $this->rows[] = $row ;
  17. break ;
  18. }
  19.  
  20. file_put_contents ( $this->cacheFile , serialize ( $this->rows ) ) ;
  21.  
  22. return $this->array ;
  23. }
  24. }
  25. ?>


Jak mówiłem, bardzo proste odczytanie. Wyświetlić chce za pomocą
  1. <?php
  2. while ( $row = sql->sqlParm() )
  3. ?>
SHiP
Gdy istnieje cache zwracasz cały cache a nie tylko jeden wiersz z bazy danych. Musisz stworzyc licznik i poprawić klilka linijek.
  1. <?php
  2. if ( $this->cacheStatus == 1 ) 
  3. {
  4. $this->array = unserialize ( file_get_contents ( $this->cacheFile ) ) ;
  5.  
  6. return $this->array[$this -> cacheCounter++] ;
  7. }
  8. ?>


Powinno działać winksmiley.jpg Chociaz odczytywanie cachu za kazdym razem lekko mija sie z celem wiec lepiej sprawdzic czy juz jest odczytany lub stworzyc do tego oddzielna metode
Moli
Temat można już zamknąć smile.gif Już dawno i zupełnie inaczej to rozwiązałem smile.gif
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.