Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP]Wyciąganie danych z bazy danych za pomocą foreach
Forum PHP.pl > Forum > Przedszkole
Konop857
Witam

Mam problem z pętlą foreach, otóż gdy mój kod wygląda następująco :

  1. class sql {
  2. function query($query){
  3. }}

  1. $query = $SQL->query("SELECT * FROM wacc_news");
  2. foreach($query as $news){
  3. $content = $news;
  4. }


Wyświetla mi się zawartość wszystkich kolumn po kolei.

Gdy zmienię ten kawałek kodu :
  1. $content = $news;


Na :
  1. $content = $news['message']; //Nazwa obojętnie jakiej kolumny


Wyświetla mi się duża litera T.

Mógłby mi ktoś wytłumaczyć w czym robie błąd?

Pozdrawiam
lobopol
Najprościej sprawdź sobie co tam masz print_r albo var_dump na $query. Jako dodatkową informacje dodam, że to co zrobiłeś jest błędem bo pobierasz zawartość całej tabeli, ale zwracasz sobie tylko jeden rekord.

W $query masz aktualnie albo false gdy zapytanie było zwróciło nic albo tablicę poindeksowaną nazwami pól w tabeli. pętlą foreach wyświetlasz sobie całą zawartość tej tablicy, ale w niej już nie masz wpisu który jest tablicą i ma index np. message, tutaj możesz wyświetlić:
  1.  
  2. $query = $SQL->query("SELECT * FROM wacc_news");
  3.  
  4. $content = $query['message'] ;
  5.  
Konop857
Użyłem var_dump i o to co uzyskałem :
  1. string(1) "1" string(1) "T" string(1) "D"

Mam 3 kolumny w bazie danych (id, title oraz message).
Id = 1
Title = Test
Message = Dupa

Widzę że wyświetlają mi się pierwsze litery wyrazów, co zrobić by wyświetlała się pełna zawartość komórki?

Pozdrawiam
wujek2009
Ogólnie Twoja klasa jest strasznie słaba - tak na szybko:

a) rozbij zapytania
$query = mysql_query();
$row = mysql_fetch_assoc($query);

cool.gif do mysql_query() dodaj mysql_error() sprawdzaj czy zapytanie Ci się wykonało.

markonix
Nie każde zapytanie musi zwracać wynik.
Przecież np. będę chciał zrobić update i nie chce wyniku, ewentualnie chce rezultat w postaci prawy/fałsz czy update został wykonany.
Tak samo insert.
crocodillo
Tak jak już wspomniane było całość masz bardzo źle napisane - nielogicznie. Poza tym Twoja funkcja query() zwraca tylko pierwszy wynik otrzymany z zapytania. Jeśli chcesz mieć wszystkie wyniki to funkcja powinna wyglądać np tak:
  1. function query($query){
  2. return mysql_query($query);
  3. }

i przetwarzaj wyniki np tak:
  1. $query = $SQL->query("SELECT * FROM wacc_news");
  2. while ($news = mysql_fetch_assoc($query)) {
  3. $content = $news['message'];
  4. }
markonix
Można zrobić coś na wzór PDOStatement::fetchAll jednakże nie jest to zalecane ze względu na optymalność pakowania całego wyniku jednorazowo w tablicę.
Osobiście raz się już na tym sparzyłem (tablica przekroczyła pamięć dostępną dla skryptu).
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.