Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MySQL][PHP]Wyciąganie danych z bazy danych za pomocą foreach, [MySQL][PHP]Wyciąganie danych z bazy danych za pomocą foreach
Konop857
post 14.04.2012, 19:29:53
Post #1





Grupa: Zarejestrowani
Postów: 81
Pomógł: 2
Dołączył: 4.05.2011

Ostrzeżenie: (10%)
X----


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
Go to the top of the page
+Quote Post
lobopol
post 14.04.2012, 19:46:28
Post #2





Grupa: Zarejestrowani
Postów: 1 729
Pomógł: 346
Dołączył: 4.04.2009

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


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.  


--------------------
Go to the top of the page
+Quote Post
Konop857
post 14.04.2012, 20:09:31
Post #3





Grupa: Zarejestrowani
Postów: 81
Pomógł: 2
Dołączył: 4.05.2011

Ostrzeżenie: (10%)
X----


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
Go to the top of the page
+Quote Post
wujek2009
post 14.04.2012, 20:26:18
Post #4





Grupa: Zarejestrowani
Postów: 350
Pomógł: 31
Dołączył: 23.05.2010

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


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.

Go to the top of the page
+Quote Post
markonix
post 14.04.2012, 21:42:13
Post #5





Grupa: Zarejestrowani
Postów: 2 707
Pomógł: 290
Dołączył: 16.12.2008
Skąd: Śląsk

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


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.


--------------------
Go to the top of the page
+Quote Post
crocodillo
post 14.04.2012, 22:07:43
Post #6





Grupa: Zarejestrowani
Postów: 215
Pomógł: 44
Dołączył: 31.07.2011
Skąd: wrocław

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


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. }
Go to the top of the page
+Quote Post
markonix
post 14.04.2012, 23:59:12
Post #7





Grupa: Zarejestrowani
Postów: 2 707
Pomógł: 290
Dołączył: 16.12.2008
Skąd: Śląsk

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


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).

Ten post edytował markonix 14.04.2012, 23:59:39


--------------------
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 Wersja Lo-Fi Aktualny czas: 20.05.2025 - 05:40