Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [php/mysql] Zapisywanie do tablicy checkedbox'ów
insenic
post
Post #1





Grupa: Zarejestrowani
Postów: 19
Pomógł: 0
Dołączył: 9.02.2007

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


Jeżeli do skryptu przez formularz zostają przesłane następujące pola:

  1. <input type="checkbox" name="test" value="1" />
  2. <input type="checkbox" name="test" value="2" />
  3. <input type="checkbox" name="test" value="3" />
  4. <input type="checkbox" name="test" value="4" />
  5. <input type="checkbox" name="test" value="5" />


Jak teraz zapisać do tabeli (mysql), te które zostały zaznaczone?

Tabela ma taką postać
Kod
[id]    [pole1]     [test]


Chciałbym dodać do tej tabeli wszystkie zaznaczone pola, przy czym 'pole1' powinno mieć inną, ustaloną przezemnie wartość np. 'znak'
Go to the top of the page
+Quote Post
juzwa
post
Post #2





Grupa: Zarejestrowani
Postów: 144
Pomógł: 0
Dołączył: 10.07.2006

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


ja to robię tak

wybieram jakąś nazwę + liczbę

np parametr_1, parametr_2, parametr_3 itd

i w skrypcie przetwarzam to tak (przykładowo)


  1. <?php
  2. for($i=1;$i<6;$i++)
  3. {
  4.  if($_POST['parametr_'.$i])
  5.  {
  6. //oznacza, że jest zaznaczony i można coś tam wykonać co się chce
  7. }
  8.  
  9. }
  10. ?>


----------------------
Jeśli chcemy dać kod na forum umieszczamy go
w odpowiednich tagach, tym razem poprawiłem,
ale na przyszłość proszę się do tego stosować.
---
~strife
Go to the top of the page
+Quote Post
mokry
post
Post #3





Grupa: Zarejestrowani
Postów: 374
Pomógł: 23
Dołączył: 3.06.2006
Skąd: Katowice

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


Musisz mieć

name="test[]" aby powstała tablica. Potem pętelką sobie zapisz wszystkie dane do MySQLa
Go to the top of the page
+Quote Post
insenic
post
Post #4





Grupa: Zarejestrowani
Postów: 19
Pomógł: 0
Dołączył: 9.02.2007

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


Tyle na razie w sumie wiedziałem. Chciałem się dowiedzieć czy istnieje możliwość zapisania tego w jednym zapytaniu, bo jak będzie tych chceckedbox'ów 100 to będę musiał wykonać 100 zapytań, a to już jest nie do przyjęcia...
Go to the top of the page
+Quote Post
misiek172
post
Post #5





Grupa: Zarejestrowani
Postów: 656
Pomógł: 3
Dołączył: 26.10.2005
Skąd: Częstochowa

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


eh a po co tyle? (IMG:http://forum.php.pl/style_emoticons/default/snitch.gif) nie lepiej checkboxy w serialize i raz do bazy?
Go to the top of the page
+Quote Post
insenic
post
Post #6





Grupa: Zarejestrowani
Postów: 19
Pomógł: 0
Dołączył: 9.02.2007

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


W tym cała rzecz, że każdego checkedbox'a muszę mieć w osobnym rekordzie bo odpowiadają one za uprawnienia na stronie...


EDIT:

Już sobie poradziłem, dla tych co będą mieli podobny problem zamieszczam rozwiązanie.
  1. <?php
  2. foreach( $arrTable as $intValue )
  3. {
  4. $strQueryString .= '( "' . $intValue . '" ),';
  5. }
  6. $strQueryString = substr( $strQueryString, 0, strlen( $strQueryString ) - 2 );
  7. ?>
Potem doklejamy to do początku zapytania, które wstawia dane do tabeli...

Ten post edytował insenic 22.02.2007, 20:39:35
Go to the top of the page
+Quote Post
misiek172
post
Post #7





Grupa: Zarejestrowani
Postów: 656
Pomógł: 3
Dołączył: 26.10.2005
Skąd: Częstochowa

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


mogłeś to wrzucić to jednej komórki w tabeli w formie 1-0-0-1-1-1-1-0 i przy wyciąganiu ich z bazy tylko explode();
Go to the top of the page
+Quote Post
insenic
post
Post #8





Grupa: Zarejestrowani
Postów: 19
Pomógł: 0
Dołączył: 9.02.2007

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


Mógłbym, jeżeli kolejność wartości (checked box) zawsze była by taka sama (ewentualnie musiał bym ją gdzieś zapisywać), a z założenia mojego cms, jest to mało prawdopodobne. To co napisałem działa jak najbardziej poprawnie...
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: 24.08.2025 - 09:47