Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [PHP][MySQL] Pętla foreach
raval
post 21.04.2011, 20:49:09
Post #1





Grupa: Zarejestrowani
Postów: 100
Pomógł: 0
Dołączył: 1.04.2011

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


Witam,

mam pytanie związane z pętlą foreach. Otóż jak zapisac w php do tablicy asocjacyjnej wszystkie wartości, a raczej wszystkie wiersze z tabeli baz danych?

  1. $zap = "SELECT * FROM `lista`";
  2. $wys = mysql_query($zap) or die(mysql_error());
  3. $a = mysql_fetch_assoc($wys);
  4.  
  5. foreach ($a as $key => $value)
  6. {
  7. $PobierzZbazy[$key] = $value;
  8. }


Dokładnie chodzi mi o to, że przy powyższym przykładzie zapisze mi tylko wartości z pierwszego wiersza Tabeli to tablicy asocjacyjnej, ale jak zrobić, by zapisał do niej wszystkie wiersze?

Ten post edytował raval 21.04.2011, 20:51:44
Go to the top of the page
+Quote Post
matino
post 21.04.2011, 21:13:22
Post #2





Grupa: Zarejestrowani
Postów: 175
Pomógł: 30
Dołączył: 9.08.2007

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


  1. $i = 0;
  2. while ($a = mysql_fetch_assoc($wys))
  3. {
  4. foreach ($a as $key => $value)
  5. {
  6. $PobierzZbazy[$i++][$key] = $value;
  7. }
  8. }
Go to the top of the page
+Quote Post
thek
post 22.04.2011, 01:48:47
Post #3





Grupa: Moderatorzy
Postów: 4 362
Pomógł: 714
Dołączył: 12.02.2009
Skąd: Jak się położę tak leżę :D




Kolejna pętla foreach już używająca $PobierzZbazy? wink.gif


--------------------
Najpierw był manual... Jeśli tam nie zawarto słów mądrości to zapytaj wszechwiedzącego Google zadając mu własciwe pytania. A jeśli i on milczy to Twój problem nie istnieje :D
Go to the top of the page
+Quote Post
raval
post 22.04.2011, 09:18:02
Post #4





Grupa: Zarejestrowani
Postów: 100
Pomógł: 0
Dołączył: 1.04.2011

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


Cytat(matino @ 21.04.2011, 22:13:22 ) *
  1. $i = 0;
  2. while ($a = mysql_fetch_assoc($wys))
  3. {
  4. foreach ($a as $key => $value)
  5. {
  6. $PobierzZbazy[$i++][$key] = $value;
  7. }
  8. }


Jestem troche z w tym zielony i jak w tym przypadku, (ale juz nie w petli pobierania z BD) moge odczytac 5, albo 7 wiersz ktory zostal wrzucony do tablicy $PobierzZbazy??
Go to the top of the page
+Quote Post
nospor
post 22.04.2011, 09:20:52
Post #5





Grupa: Moderatorzy
Postów: 36 556
Pomógł: 6314
Dołączył: 27.12.2004




zajrzyj może do manuala i zapoznaj się z podstawami rzeczy, których planujesz używać?

print_r($PobierzZbazy[5]);

http://pl.php.net/manual/pl/language.types.array.php


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
raval
post 22.04.2011, 09:44:34
Post #6





Grupa: Zarejestrowani
Postów: 100
Pomógł: 0
Dołączył: 1.04.2011

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


Zastanawia mnie w jaki sposób działa ta inkrementacja i jak tym samym sposobem moge ja odczytac questionmark.gif:

  1. $PobierzZbazy[$i++][$key] = $value;


Prosiłbym o wytłumaczenie :X


Nie wiem czy dobrze rozuemim, czy mniej wiecej tak on zapisuje do tablicy?:
  1. $PobierzZbazy['klucz0'] = array("value0", "value1", "value2" );
  2. $PobierzZbazy['klucz1'] = array("value0", "value1", "value2" );
  3. $PobierzZbazy['klucz2'] = array("value0", "value1", "value2" );


Co do manuala, ciezko moge sie dopatrzec swojego problemu.
Go to the top of the page
+Quote Post
nospor
post 22.04.2011, 09:48:39
Post #7





Grupa: Moderatorzy
Postów: 36 556
Pomógł: 6314
Dołączył: 27.12.2004




Cytat
Nie wiem czy dobrze rozuemim, czy mniej wiecej tak on zapisuje do tablicy?:
Kurcze... zrób sobie
print_r($PobierzZbazy)
a zobaczysz jak on to zapisał.

Cytat
Co do manuala, ciezko moge sie dopatrzec swojego problemu.
Ty nie masz się tam dopatrzeć swojego problemu a zapoznać się podstawiami obsługi tablic. Jak zrozumiesz co to tablica i jak działa to będzie łatwiej


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
kosmos
post 26.03.2014, 14:42:44
Post #8





Grupa: Zarejestrowani
Postów: 367
Pomógł: 17
Dołączył: 4.03.2008

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


Witam,

dodaje do tego wątku bo mój przykład również ogólnie tyczy sie petli foreach.

Jest taki fragment kodu (z tutoriala KOHANA)


  1. foreach ($script as $key => $value)
  2. echo Html::script($value);


Zmienna script to jak wiadomo zmienna tablicowa, gdzie pętla leci po kluczu i wartości tej tabli. Nie rozumiem natomiast sposobu wyświetlania czyli drugiej linijki.
Przykład z tego tutoriala:

http://kohana-php.com.pl/pierwsza-strona/

Co robi ten dwukropek? skąd HTML?

Ten post edytował kosmos 26.03.2014, 14:45:34
Go to the top of the page
+Quote Post
nospor
post 26.03.2014, 14:46:40
Post #9





Grupa: Moderatorzy
Postów: 36 556
Pomógł: 6314
Dołączył: 27.12.2004




Problem nie ma zadnego zwiazku z FOREACh......
HTML - to klasa
a :: oznacza wywolanie metody statycznej w klasie w tym wypadku wywolanie metody script() w klasie HTML.

Ale to są podstawy klas, wiec skoro uzywasz Kohany to wypadaloby sie z tymi podstawami zapoznac


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

Go to the top of the page
+Quote Post
kosmos
post 26.03.2014, 14:53:55
Post #10





Grupa: Zarejestrowani
Postów: 367
Pomógł: 17
Dołączył: 4.03.2008

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


Już nie przesadzaj z tym że w ogóle nie dotyczy wink.gif
Czyli bez tworzenia obiektu klasy HTML, z klasy tej wywoływana jest metoda scritp() z parametrem będącym wartością tablicy znajdującej się w zmiennej $script .

Ok dzięki
Go to the top of the page
+Quote Post
nospor
post 26.03.2014, 14:56:59
Post #11





Grupa: Moderatorzy
Postów: 36 556
Pomógł: 6314
Dołączył: 27.12.2004




Cytat
Już nie przesadzaj z tym że w ogóle nie dotyczy
Bo nie dotyczy... .to ze linijke wyzej jest FOREACH nie ma w twoim problemie zadnego znaczenia... Nastepnym razem nie wcinaj sie bez sensu tak w tematy tylko staraj sie zrozumiec czego dotyczy twoj problem i zakladaj oddzielne tematy
Powód edycji: [nospor]:


--------------------

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

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: 3.05.2025 - 07:50