Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Zmienna dynamiczna
Tomplus
post
Post #1





Grupa: Zarejestrowani
Postów: 1 879
Pomógł: 230
Dołączył: 20.03.2005
Skąd: Będzin

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


Mam problem którego nie daje rady już rozwiązać, ze zmienną dynamiczną:

  1. <?
  2. $test1="Test udany!"
  3. for ($z=1; $z<5; $z++)
  4. {
  5. $k="k".$z;
  6. $test="test".$z;
  7. echo $$test; 
  8.  
  9. $query="SELECT * FROM tabela WHERE id='$z';";
  10. $res=zapytaj($query);
  11. echo $$k['id'];
  12. }
  13. ?>


Wynik: k1, a powinnien wyświetlic się w tym wypadku numer id jaki był w zapytaniu (tylko bez zarzutów po co mi zwrot ID)

Korzystając ze zmiennej dynamicznej normalnie w pętli FOR pokazują się dane prawidłowo w moim wypadku jest nim $test1.
ale nie wiem dlaczego korzystając z niej do MySQL daje mi wynik samej zmiennej, a nie z tablicy?

Ten post edytował Tom+ 12.09.2005, 08:36:03
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 7)
czachor
post
Post #2





Grupa: Zarejestrowani
Postów: 897
Pomógł: 40
Dołączył: 16.12.2003
Skąd: Warszawa

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


Nie wiem, czy dobrze zrozumiałem...
  1. <?php
  2. echo ${$k['id']};
  3. ?>


Ten post edytował czachor 8.09.2005, 22:20:18
Go to the top of the page
+Quote Post
batman
post
Post #3





Grupa: Moderatorzy
Postów: 2 921
Pomógł: 269
Dołączył: 11.08.2005
Skąd: 127.0.0.1




A w którym miejscu zamykasz pętle for ?
Go to the top of the page
+Quote Post
dr_bonzo
post
Post #4





Grupa: Przyjaciele php.pl
Postów: 5 724
Pomógł: 259
Dołączył: 13.04.2004
Skąd: N/A

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


Cytat
A w którym miejscu zamykasz pętle for ?

Pewnie na koncu -- zobacz dokad uzywa zmiennej $z (w zapytaniu, a potem uzywa wyniki zapytania)

Nie dodawaj srednika w zapytaniu w php.

  1. <?php
  2. $k = 'k' . $z;
  3. ?>

A znasz tablice wielowymiarowe?
  1. <?php
  2. $k[ $z ] = mysql_fetch_array($res);
  3. print( $k[ $z ][ 'id' ] );
  4. ?>




@czachor:
echo ${$k['id']};

raczej

echo {$$k}['id']; // choc nie wiem czy takie cos przejdzie
bo index 'id' jest dopiero w tablicy $$k czyli $k1, $k2,...
Go to the top of the page
+Quote Post
Tomplus
post
Post #5





Grupa: Zarejestrowani
Postów: 1 879
Pomógł: 230
Dołączył: 20.03.2005
Skąd: Będzin

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


@dr_bonzo:
probowalem juz wczesniej tej tablicy ale nie wystwietlalo zupelnie zadnych informacji

a co do $$k{['id']} to wychodzi blad parsera

@czachor
jezeli wolisz tak, jednak wychodzi to samo pokazuje TYLKO nazwe zmiennej a nie to co przecowuje ta zmienna.

@batman
poprawilem kod, teraz widac gdzie sie zamyka
Go to the top of the page
+Quote Post
nospor
post
Post #6





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




  1. <?php
  2.  
  3. echo ${$k}['id'];
  4.  
  5. ?>
Działa, testowałem (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Nie zadziala, gdy nie będzie danego id w bazie. Znaczy zadziała, tylko nic nie wyswietli

No ale można też na tablicach:
  1. <?php
  2.  
  3. $test1="Test udany!"
  4. $ar = array();//nowy kod
  5. for ($z=1; $z<5; $z++)
  6. {
  7. $k="k".$z;
  8. $test="test".$z;
  9. echo $$test; 
  10.  
  11. $query="SELECT * FROM tabela WHERE id='$z'";
  12. $res=zapytaj($query);
  13. $ar[$z]=mysql_fetch_array($res);//nowy kod
  14. echo $ar[$z]['id'];//nowy kod
  15. }
  16.  
  17. ?>
tez dziala (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
Tomplus
post
Post #7





Grupa: Zarejestrowani
Postów: 1 879
Pomógł: 230
Dołączył: 20.03.2005
Skąd: Będzin

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


wcześniej nie działało, numery ID były i to więcej niż w pytaniu.

ale fakt teraz działa, nie wiem w jaki sposób poprzednie wskazówki nie działały mi, ale teraz działa i mogę dalej tworzyć skrypt który zaczałem.

Dzięki za pomoc, wszystkim!
Go to the top of the page
+Quote Post
Sfinx
post
Post #8





Grupa: Zarejestrowani
Postów: 1
Pomógł: 0
Dołączył: 27.12.2007

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


Mam pytanie:
Chcę zrobić coś takiego:
Kod
$sha1($zmienna)

Ale sha1 traktuje jako zmienną.
Go to the top of the page
+Quote Post

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

 



RSS Aktualny czas: 23.08.2025 - 18:28