Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> PHP + mySQL + checkboxy
mgregor
post
Post #1





Grupa: Zarejestrowani
Postów: 13
Pomógł: 0
Dołączył: 9.06.2004
Skąd: Warszawa

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


Jest sobie nastepujacy formularz:

[php:1:c0f6c610e7]
<?php

$link = mysql_connect("xxx", "xxx", "xxx")
or die ("Nie można się połączyć");

mysql_select_db ("xxx") or die ("Nie mozna wybrać bazy danych");

$query = mysql_query("SELECT * FROM `cd`");
while($dane = mysql_fetch_array($query))
{
print '<form action="porownaj.php" method="get">';
print '<input type="checkbox" name="Id" value="'.$dane['Id'].'">';
print ''.$dane['Producent'].' '.$dane['Typ'].' '.$dane['Model'].'<br>';
}
print '<button type="reset" name="reset">Skasuj</button>';
print '<input type="submit" value="Porównaj">';
print '</form>';

mysql_close($link);
?>
[/php:1:c0f6c610e7]

i do tego plik wyswietlajacy porownaj.php o tresci nastepujacej:

[php:1:c0f6c610e7]
<?php

$link = mysql_connect("xxx", "xxx", "xxx")
or die ("Nie można się połączyć");

mysql_select_db ("xxx") or die ("Nie mozna wybrać bazy danych");

$query = "SELECT * FROM `cd` WHERE Id='$_GET[Id]'";
$result = mysql_query ($query) or die ("Zapytanie zakończone niepowodzeniem");

while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {
$a=0;
foreach ($line as $col_value) {
print "<b>";
echo mysql_field_name($result, $a++);
echo ":n";
print "</b>";
print "$col_value<br>";

}
}

mysql_free_result($result);

mysql_close($link);
?>
[/php:1:c0f6c610e7]

I teraz mam problem poniewaz po wybraniu pol z formularza (checkbox'y) i kliknieciu wyslij dostaje adres w formie:
porownaj.php?Id=1&Id=4 (po wybraniu produktow o Id=1 i Id=4).
i porownaj.php wyswietla mi tylko ten produkt o Id=4. Jak zrobic zeby wyswietlil mi oba (albo wiecej jesli zostana zaznaczone)? Wiem ze musi to byc zapytanie w stylu: SELECT * FROM `tabela` WHERE Id=1 OR Id=4 . Moze ktos pomoze?

Pozdrawiam serdecznie
mgregor
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 5)
kszychu
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 2 712
Pomógł: 23
Dołączył: 27.10.2003
Skąd: z kontowni

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


nazwij checkboxy id[] i później w php operuj na tablicy $id
Go to the top of the page
+Quote Post
mgregor
post
Post #3





Grupa: Zarejestrowani
Postów: 13
Pomógł: 0
Dołączył: 9.06.2004
Skąd: Warszawa

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


A mozesz troche jasniej? Np. co gdzie zmienic?
Go to the top of the page
+Quote Post
kszychu
post
Post #4





Grupa: Przyjaciele php.pl
Postów: 2 712
Pomógł: 23
Dołączył: 27.10.2003
Skąd: z kontowni

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


A czego nie rozumiesz? Tego, żeby nazwać checkboxy id[]:
[php:1:3edc0fa5cd]<?php
print '<input type="checkbox" name="Id[]" value="'.$dane['Id'].'">';
?>[/php:1:3edc0fa5cd]
Czy nie wiesz jak się później odwoływać do tablicy $id czyli $_GET[id]?
Go to the top of the page
+Quote Post
mgregor
post
Post #5





Grupa: Zarejestrowani
Postów: 13
Pomógł: 0
Dołączył: 9.06.2004
Skąd: Warszawa

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


Wlasnie nie rozumiem tego drugiego tj. odwolania do tablicy...jak to wykonac zeby wyszlo poprawne zapytanie. Rozumiem ze Id[] tworzy w pamieci tablice Id i do niej wpisuje poszczegolne numery Id ktore dostaje od formularza. A potem? Jak to wykorzystac przy wybieraniu z bazy?

Dodane 10.06.2004:

No i poradzilem sobie :-) Znalazlem na forum ze 3 watki o tym i z 3 sklecilem jeden. A to tak dla potomnych (moze ktos cos z tego bedzie mial):

Formularz wybierania...

[php:1:65fd1475f7]
<?php

$link = mysql_connect("xxx", "xxx", "xxx")
or die ("Nie można się połączyć");

mysql_select_db ("xxx") or die ("Nie mozna wybrać bazy danych");

$query = mysql_query("SELECT * FROM `cd`");
while($dane = mysql_fetch_array($query))
{
print '<form action="porownaj.php" method="get">';
print '<input type="checkbox" name="wybrane[]" value='.$dane['Id'].'>';
print ''.$dane['Producent'].' '.$dane['Typ'].' '.$dane['Model'].'<br>';
}
print '<button type="reset" name="reset">Skasuj</button>';
print '<input type="submit" value="Porównaj">';
print '</form>';

mysql_close($link);
?>
[/php:1:65fd1475f7]

...przesyla numery Id w tablicy wybrane[] do nastepujacego skryptu...

[php:1:65fd1475f7]
<?php

$link = mysql_connect("xxx", "xxx", "xxx")
or die ("Nie można się połączyć");

mysql_select_db ("xxx") or die ("Nie mozna wybrać bazy danych");

$query = "SELECT * FROM `cd` WHERE Id IN (". implode(",", $wybrane) .");";
$result = mysql_query ($query) or die ("Zapytanie zakończone niepowodzeniem");

while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {
$a=0;
foreach ($line as $col_value) {
print "<b>";
echo mysql_field_name($result, $a++);
echo ":n";
print "</b>";
print "$col_value<br>";

}
}

mysql_free_result($result);

mysql_close($link);
?>
[/php:1:65fd1475f7]

I pieknie wyswietla wszystkie pola z bazy o zadanych Id. Teraz tylko sformatowac to jakos ladnie i gotowe.

Pozdrawiam wszystkich
mgregor
Go to the top of the page
+Quote Post
kszychu
post
Post #6





Grupa: Przyjaciele php.pl
Postów: 2 712
Pomógł: 23
Dołączył: 27.10.2003
Skąd: z kontowni

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


Cytat
No i poradzilem sobie :-) Znalazlem na forum ze 3 watki o tym i z 3 sklecilem jeden.


Gdybym mógł, dostałbyś za to ode mnie dużego plusa! (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Pozdrawiam i życzę powodzenia
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: 22.08.2025 - 16:34