Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP][PDO] Problem z wyciągnięciem tablicy poza pętlę
Barton
post
Post #1





Grupa: Zarejestrowani
Postów: 70
Pomógł: 2
Dołączył: 26.10.2008

Ostrzeżenie: (0%)
-----


Witam,

Napisałem następujący fragment kodu:

  1. <?php
  2. try {
  3.    $pdo = new PDO('mysql:host=localhost;dbname=...', '...', '...');
  4.    $pdo -> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  5.    $query = $pdo -> prepare('SELECT * FROM fb_messages WHERE fb_to = :to');
  6.    $query -> bindValue(':to', $user_info[2], PDO::PARAM_STR);
  7.    $query -> execute();
  8.    while($row = $query -> fetch(PDO::FETCH_ASSOC)) {
  9.        $data[] = $row;
  10.    }
  11.  
  12.    $query -> closeCursor();
  13.    
  14.    
  15. }
  16. catch(PDOException $e) {
  17.      echo $e->getMessage();
  18. }
  19. ?>


Tablica $row tworzy się, ale posiada zawartość tylko w pętli while, co wydaje się dość logiczne. Niemniej jednak próbuję przepisać ją do $data[] aby móc z niej potem skorzystać. Niestety nie mogę, ponieważ tablica $row nie przepisuje się do $data[]. Zastanawiam się czy to może wina closeCursor()? Proszę Was drodzy doświadczeni koledzy o pomoc. winksmiley.jpg

Pozdrawiam.

Ten post edytował Barton 6.11.2008, 20:24:39
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 12)
michalg
post
Post #2





Grupa: Zarejestrowani
Postów: 122
Pomógł: 8
Dołączył: 20.10.2008

Ostrzeżenie: (0%)
-----


Napewno jest pusta? zrób print_r($data) przed i po closeCursor();

Jak korzysztasz z data?

Ten post edytował michalg 6.11.2008, 20:31:04
Go to the top of the page
+Quote Post
bim2
post
Post #3





Grupa: Zarejestrowani
Postów: 1 873
Pomógł: 152
Dołączył: 9.04.2006
Skąd: Berlin

Ostrzeżenie: (0%)
-----


musi coś tam być, żeby uniknac notica wstaw jeszcze przed while $data = array()


--------------------
Go to the top of the page
+Quote Post
Barton
post
Post #4





Grupa: Zarejestrowani
Postów: 70
Pomógł: 2
Dołączył: 26.10.2008

Ostrzeżenie: (0%)
-----


Rzeczywiście... Oo Tablica jest zapisana. Ale jakiekolwiek wywołanie echo $data['fb_title']; nic nie zwraca... Oo To samo ze dzieje się dalej ze smarty. Przytoczę dalszą część kodu:

plik1.php
  1. <?php
  2. ...
  3. $smarty->assign('data', $data);
  4. ...
  5. ?>


plik2.tpl
  1. ...
  2. {foreach from=$data item=row}
  3. <tr class="next_messages">
  4. <td><img src="template/images/icons/email.png" /></td>
  5. <td>{$row.fb_from}</td>
  6. <td>{$row.fb_title}</td>
  7. <td>{$row.fb_date}</td>
  8. </tr>
  9. {/foreach}
  10. ...
Go to the top of the page
+Quote Post
michalg
post
Post #5





Grupa: Zarejestrowani
Postów: 122
Pomógł: 8
Dołączył: 20.10.2008

Ostrzeżenie: (0%)
-----


Ale dlaczego robisz $data['fb_title'] ? Przecież masz tablicę dwuwymiarową, więc jak już, to powinieneś robić $data[$r]['fb_title'] gdzie $r to nr kojelnego wiersza.

Edit:
Teraz zauważyłem że w smarty używasz row. Więc może tam jest jakiś błąd.

Ten post edytował michalg 6.11.2008, 20:46:13
Go to the top of the page
+Quote Post
bim2
post
Post #6





Grupa: Zarejestrowani
Postów: 1 873
Pomógł: 152
Dołączył: 9.04.2006
Skąd: Berlin

Ostrzeżenie: (0%)
-----


@up
przeciez tak robi...

Musisz gdzieś 'tracic' tą zmienną.


--------------------
Go to the top of the page
+Quote Post
michalg
post
Post #7





Grupa: Zarejestrowani
Postów: 122
Pomógł: 8
Dołączył: 20.10.2008

Ostrzeżenie: (0%)
-----


Cytat(bim2 @ 6.11.2008, 20:45:42 ) *
@up
przeciez tak robi...

Chodziło mi o echo $data['fb_title'];

Nie znam się na smarty, ale czy przypadkiem zamiast item=row nie powinno być item=$row?
Go to the top of the page
+Quote Post
Barton
post
Post #8





Grupa: Zarejestrowani
Postów: 70
Pomógł: 2
Dołączył: 26.10.2008

Ostrzeżenie: (0%)
-----


@bim2, michalg: przedewszystkim dzięki za zaangażowanie. Ale, damn it! Zaraz po wyswietleniu tego echo daje print_r($data) i ta tablica wciąż tam jest... sad.gif

michalg: print($data[0]['fb_title']); rzeczywiście zadziałało... tylko teraz jak to przenieść do tej pętli foreach w tpl? biggrin.gif

Ten post edytował Barton 6.11.2008, 20:51:09
Go to the top of the page
+Quote Post
michalg
post
Post #9





Grupa: Zarejestrowani
Postów: 122
Pomógł: 8
Dołączył: 20.10.2008

Ostrzeżenie: (0%)
-----


A możesz fragment wyniku tego print_r wkleić? Żeby tylko zobaczyć strukturę tej tablicy.

Ten post edytował michalg 6.11.2008, 20:50:30
Go to the top of the page
+Quote Post
Barton
post
Post #10





Grupa: Zarejestrowani
Postów: 70
Pomógł: 2
Dołączył: 26.10.2008

Ostrzeżenie: (0%)
-----


Pewnie.

Kod
Array ( [0] => Array ( [fb_id] => 1 [fb_title] => Elo elo, trzy dwa kurwa zero! [fb_text] => xxx [fb_from] => xxx [fb_to] => xxx [fb_date] => [fb_read] => 0 ) )


A co do item=$row, nie powinno być item=row. winksmiley.jpg
Go to the top of the page
+Quote Post
michalg
post
Post #11





Grupa: Zarejestrowani
Postów: 122
Pomógł: 8
Dołączył: 20.10.2008

Ostrzeżenie: (0%)
-----


Wygląda, że tablica jest w porządku.

A możesz w tym tpl wykonać kod php i tam wyświetlić print_r($data)? A może już tak zrobiłeś?
Go to the top of the page
+Quote Post
Barton
post
Post #12





Grupa: Zarejestrowani
Postów: 70
Pomógł: 2
Dołączył: 26.10.2008

Ostrzeżenie: (0%)
-----


Nie da rady. W zasadzie teraz problemem jest, w jaki sposób w templatce wyświetlić tą tablice... Dodam że jeden wiersz wyświetla. Z tym że bez żadnych danych...

  1. {section name=i loop=$data}
  2. <tr class="next_messages">
  3. <td><img src="template/images/icons/email.png" /></td>
  4. <td>{$data[i].fb_from}</td>
  5. <td>{$data[i].fb_title}</td>
  6. <td>{$data[i].fb_date}</td>
  7. </tr>
  8. {/section}


Daje ten sam efekt...

Ten post edytował Barton 6.11.2008, 21:09:56
Go to the top of the page
+Quote Post
bim2
post
Post #13





Grupa: Zarejestrowani
Postów: 1 873
Pomógł: 152
Dołączył: 9.04.2006
Skąd: Berlin

Ostrzeżenie: (0%)
-----


pokaż cały kod php, od momentu pobrania do przypisania zmiennej. Musisz gdzieś ją gupić, jeśli do smarty nie przekazujesz.


--------------------
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 19.08.2025 - 19:09