Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: как вывести на экран отмеченные чекбоксом строки из базы?
Форумы портала PHP.SU » PHP » Программирование на PHP » как вывести на экран отмеченные чекбоксом строки из базы?

Страниц (1): [1]
 

1. zlovred - 08 Июля, 2008 - 12:22:59 - перейти к сообщению
У меня из базы данных выводятся в браузер строки. Напротив каждой строки установлен чекбокс с именем $box[$i]. Пользователь отметив нужные ему строки и нажав на кнопку должен увидеть на экране только отмеченные строки. Проблема заключается в следующем: не знаю как составить для этого запрос, и как получить каждому отмеченному чекбоксу соответствующий идентификатор (id) строки в базе данных.
2. kamikadze - 08 Июля, 2008 - 12:54:50 - перейти к сообщению
1) Использование Ключей (праймари кей) с автоинкриментом (в БД)
2) Использование передачи данных формы (POST тут самый раз)
Ставим к строкам ключи, $id - значение этого уникального ключа. А с кнопкой простая форма из этих чекбоксов и кнопки.
3. valenok - 08 Июля, 2008 - 13:22:00 - перейти к сообщению
CODE (text):
скопировать код в буфер обмена
  1. SELECT * FROM `table` WHERE `id` IN (7,10,12)
4. zlovred - 08 Июля, 2008 - 13:29:08 - перейти к сообщению
zlovred пишет:

После всего етого код будет выглядеть примерно так (могу ошибаться)
CODE (text):
скопировать код в буфер обмена
  1.  
  2. while ($i<>0){
  3. $i=$i-1;
  4.        if ($box[$i]=true){
  5.        $boxx=1;
  6.        $query="select * from k where '".$boxx."'=1 and id='".$num."'";
  7.         //здесь id-primary key
  8.         //вывод данных
  9.        }else{
  10.        $boxx=0;
  11.         }
  12. }
  13.  

а где взять значение $num ?
или лучше как-нибудь подругому все организовать?
5. valenok - 08 Июля, 2008 - 13:36:36 - перейти к сообщению
У людей идеальная способность просить помощь, а потом её игнорировать ..
SELECT * FROM `table` WHERE `id` IN (7,10,12)

Сделайте print_r($_POST); и посмотрите что и как у вас передаётся на сервер.
И ещё ОЧЕНЬ рекомендую узнать о существовании других циклов и начать их использовать на практике.
6. zlovred - 08 Июля, 2008 - 13:38:54 - перейти к сообщению
Прошу прощения.
Я начал писать второе сообщение до того, как увидел ваше
7. kamikadze - 08 Июля, 2008 - 14:04:18 - перейти к сообщению
Согласен, foreach явно в данном лучше

 

Powered by ExBB FM 1.0 RC1