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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Как соеденить все значения Переменной $_POST

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Описание: в одну строчку
vlom
Отправлено: 27 Ноября, 2010 - 19:16:07
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 681
Дата рег-ции: Окт. 2010  
Откуда: Екатеринбург


Помог: 4 раз(а)




есть такая вот форма
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.  

(Отредактировано автором: 27 Ноября, 2010 - 19:21:18)

 
 Top
Мелкий Супермодератор
Отправлено: 27 Ноября, 2010 - 19:37:00
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)






-----
PostgreSQL DBA
 
 Top
ALEN
Отправлено: 27 Ноября, 2010 - 19:39:28
Post Id



Участник


Покинул форум
Сообщений всего: 1459
Дата рег-ции: Авг. 2008  
Откуда: Крым


Помог: 11 раз(а)




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

(Добавление)
Мой вариант подойдет больше, если необходима проверка каждого значения или другая какая-то обработка. Для простого соединения способ от Мелкий будет более уместным.
 
 Top
vlom
Отправлено: 27 Ноября, 2010 - 19:52:13
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 681
Дата рег-ции: Окт. 2010  
Откуда: Екатеринбург


Помог: 4 раз(а)




ALEN ваш вариант работает но почему-то вызавает
ошибку при вставке данной строки в запрос к mysql DELETE
код изменил примерно так:
PHP:
скопировать код в буфер обмена
  1. foreach($_POST['id'] as $key=>$value){
  2. $string.=$value;
  3. }
  4. echo $string;
 
 Top
Мелкий Супермодератор
Отправлено: 27 Ноября, 2010 - 19:55:42
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




vlom:
0) выведите сам запрос, что пытаетесь базе отослать. Сам запрос, а не код, который его генерит. (вольный пересказ phpfaq.ru/debug)
1) какую ошибку - секрет?

(Отредактировано автором: 27 Ноября, 2010 - 19:58:35)



-----
PostgreSQL DBA
 
 Top
vlom
Отправлено: 27 Ноября, 2010 - 20:02:51
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 681
Дата рег-ции: Окт. 2010  
Откуда: Екатеринбург


Помог: 4 раз(а)




Сори за малую не компетентность в объяснениях)))))
ошибка:
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 "Выбранные разделы удалены";
 
 Top
ALEN
Отправлено: 27 Ноября, 2010 - 20:03:13
Post Id



Участник


Покинул форум
Сообщений всего: 1459
Дата рег-ции: Авг. 2008  
Откуда: Крым


Помог: 11 раз(а)




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);
 
 Top
Мелкий Супермодератор
Отправлено: 27 Ноября, 2010 - 20:08:13
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




vlom
Мелкий пишет:
выведите сам запрос, что пытаетесь базе отослать. Сам запрос, а не код, который его генерит.


Впрочем, ошибка видна и так:
$string .= $value.', ';
На последней итерации остаётся запятая, которая и генерит при разборе ошибку.


-----
PostgreSQL DBA
 
 Top
vlom
Отправлено: 27 Ноября, 2010 - 20:14:22
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 681
Дата рег-ции: Окт. 2010  
Откуда: Екатеринбург


Помог: 4 раз(а)




ALEN ваш код удаляет перебором, разве это не дольше чем использовать код которы qgsnf.cm постороить я??


Мелкий Я это тоже понял, но опять виноват я же, в том что не правильно постороил
вопрос, как удалить последнюю запятую, может использовать str_replace() или простенькую регулярочку???
 
 Top
ALEN
Отправлено: 27 Ноября, 2010 - 20:15:42
Post Id



Участник


Покинул форум
Сообщений всего: 1459
Дата рег-ции: Авг. 2008  
Откуда: Крым


Помог: 11 раз(а)




vlom
ваш вариант красивей, я просто показал обширность выбора, а запятую удалять с помощью trim()
 
 Top
vlom
Отправлено: 27 Ноября, 2010 - 20:16:24
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 681
Дата рег-ции: Окт. 2010  
Откуда: Екатеринбург


Помог: 4 раз(а)




сори ошибочка, не str_replace(), substr_replace()
 
 Top
ALEN
Отправлено: 27 Ноября, 2010 - 20:17:20
Post Id



Участник


Покинул форум
Сообщений всего: 1459
Дата рег-ции: Авг. 2008  
Откуда: Крым


Помог: 11 раз(а)




trim($str,',')
 
 Top
vlom
Отправлено: 27 Ноября, 2010 - 20:23:10
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 681
Дата рег-ции: Окт. 2010  
Откуда: Екатеринбург


Помог: 4 раз(а)




Спасибо вам обоим огромное, весь вечер себе мозги парил с удалением,
Тема закрыта!
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB