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 :: Версия для печати :: Как соеденить все значения Переменной $_POST
Форумы портала PHP.SU » PHP » Программирование на PHP » Как соеденить все значения Переменной $_POST

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

1. vlom - 27 Ноября, 2010 - 19:16:07 - перейти к сообщению
есть такая вот форма
CODE (html):
скопировать код в буфер обмена
  1.  
  2. <form action=delete.php method=post>
  3.   <label>
  4.     <input type=checkbox name=id[] value=1 />
  5.   </label>
  6.   <label>
  7.     <input type=checkbox name=id[] value=2 />
  8.   </label>
  9.   <label>
  10.     <input type=checkbox name=id[] value=3 />
  11.   </label>
  12.   <input class="button" type="submit" name="delSections" value="Удалить"/>
  13. </form>
  14.  
  15. как соеденить все значения id в одну строку вида
  16. (id[0], id[1], id[2])
  17. если не известно какое количество параметров id будет переданно переменной пост???
  18.  
2. Мелкий - 27 Ноября, 2010 - 19:37:00 - перейти к сообщению
3. ALEN - 27 Ноября, 2010 - 19:39:28 - перейти к сообщению
PHP:
скопировать код в буфер обмена
  1. foreach($_POST['id'] as $key=>$value){
  2. $string.=$value;
  3. }
  4. echo $string;

(Добавление)
Мой вариант подойдет больше, если необходима проверка каждого значения или другая какая-то обработка. Для простого соединения способ от Мелкий будет более уместным.
4. vlom - 27 Ноября, 2010 - 19:52:13 - перейти к сообщению
ALEN ваш вариант работает но почему-то вызавает
ошибку при вставке данной строки в запрос к mysql DELETE
код изменил примерно так:
PHP:
скопировать код в буфер обмена
  1. foreach($_POST['id'] as $key=>$value){
  2. $string.=$value;
  3. }
  4. echo $string;
5. Мелкий - 27 Ноября, 2010 - 19:55:42 - перейти к сообщению
vlom:
0) выведите сам запрос, что пытаетесь базе отослать. Сам запрос, а не код, который его генерит. (вольный пересказ phpfaq.ru/debug)
1) какую ошибку - секрет?
6. vlom - 27 Ноября, 2010 - 20:02:51 - перейти к сообщению
Сори за малую не компетентность в объяснениях)))))
ошибка:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1
запрос к БД
PHP:
скопировать код в буфер обмена
  1. $sql = new functions_mysql;
  2.   $sql->connect();
  3.    if (isset($_POST['id'])){
  4.      foreach($_POST['id'] as $key=>$value){
  5.        $string .= $value.', ';
  6.      }
  7.    }else echo "Пременная \$_POST['id'] не определена";
  8.                
  9.   $result = mysql_query("DELETE FROM cms_sections WHERE id IN  ($string)") or die (mysql_error());
  10.         if ($result = false) echo "Выбранные разделы не удалены";
  11.         else echo "Выбранные разделы удалены";
7. ALEN - 27 Ноября, 2010 - 20:03:13 - перейти к сообщению
vlom
А что вы пытаетесь удалить? Вам необходимо удалить записи id которых в базе соотвествуют значениям в боксах, если да, то вот так проще сделать:

PHP:
скопировать код в буфер обмена
  1. foreach($_POST['id'] as $key=>$value){
  2. mysql_query("DELETE FROM `table` WHERE `id`='{$value}'");
  3. }


или

PHP:
скопировать код в буфер обмена
  1. $str = trim(implode("or `id`='",$_POST['id']."'"),'or ');
  2. mysql_query("DELETE FROM `table` WHERE ".$str);
8. Мелкий - 27 Ноября, 2010 - 20:08:13 - перейти к сообщению
vlom
Мелкий пишет:
выведите сам запрос, что пытаетесь базе отослать. Сам запрос, а не код, который его генерит.


Впрочем, ошибка видна и так:
$string .= $value.', ';
На последней итерации остаётся запятая, которая и генерит при разборе ошибку.
9. vlom - 27 Ноября, 2010 - 20:14:22 - перейти к сообщению
ALEN ваш код удаляет перебором, разве это не дольше чем использовать код которы qgsnf.cm постороить я??


Мелкий Я это тоже понял, но опять виноват я же, в том что не правильно постороил
вопрос, как удалить последнюю запятую, может использовать str_replace() или простенькую регулярочку???
10. ALEN - 27 Ноября, 2010 - 20:15:42 - перейти к сообщению
vlom
ваш вариант красивей, я просто показал обширность выбора, а запятую удалять с помощью trim()
11. vlom - 27 Ноября, 2010 - 20:16:24 - перейти к сообщению
сори ошибочка, не str_replace(), substr_replace()
12. ALEN - 27 Ноября, 2010 - 20:17:20 - перейти к сообщению
trim($str,',')
13. vlom - 27 Ноября, 2010 - 20:23:10 - перейти к сообщению
Спасибо вам обоим огромное, весь вечер себе мозги парил с удалением,
Тема закрыта!

 

Powered by ExBB FM 1.0 RC1