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]   

> Описание: В POST'е массив, не могу выполнить запрос.
simple-lad
Отправлено: 20 Марта, 2008 - 19:19:24
Post Id


Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Март 2008  


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




В форме несколько полей разных типов имена которых записываются как массив pr_name, например text:
CODE (text):
скопировать код в буфер обмена
  1. <input type='text' size='20' name='pr_name[$i]'>

В скрипте обработки формы пытаюсь обновить запись в БД:
PHP:
скопировать код в буфер обмена
  1. mysql_query("UPDATE db_project SET pr_name='$_POST[pr_name][$id]'");

В ответ на что в БД записывается что-то типа "Array[3]".

Хотя если эту же переменную выводить через

то на экране получаем ее значение.

Что не так с запросом и как можно решить данную проблему?
 
 Top
EuGen Администратор
Отправлено: 20 Марта, 2008 - 19:26:55
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




Скорее всего, анализатор для строковых выражений PHP не сумел правильно понять текст запроса. Вы можете попробовать сделать так:
PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3. mysql_query("UPDATE db_project SET pr_name='".$_POST['pr_name'][$id]."'");
  4. ?>
  5.  

(Отредактировано автором: 20 Марта, 2008 - 19:27:23)



-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
simple-lad
Отправлено: 20 Марта, 2008 - 19:33:36
Post Id


Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Март 2008  


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




EuGen пишет:
Скорее всего, анализатор для строковых выражений PHP не сумел правильно понять текст запроса. Вы можете попробовать сделать так:
PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3. mysql_query("UPDATE db_project SET pr_name='".$_POST['pr_name'][$id]."'");
  4. ?>
  5.  


К сожалению, не помогло Недовольство, огорчение Спасибо за помощь
 
 Top
EuGen Администратор
Отправлено: 20 Марта, 2008 - 19:35:55
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




Ну тогда Вам нужно делать отладку. Сделайте что-то вроде этого:

И конечно же http://phpfaq[dot]ru/debug


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
simple-lad
Отправлено: 20 Марта, 2008 - 19:45:34
Post Id


Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Март 2008  


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




В ответ получаю:
CODE (text):
скопировать код в буфер обмена
  1. Array ( [pr_name] => Array ( [7] => текст в первом поле [3] => текст во втором поле ))

С первого взгляда все так. Хм.. Да и то что echo выводит правильное значение переменной смущает. Если бы и так была ошибка, то было бы ясно что она не так передается. А так - не понимаю Недовольство, огорчение

(Отредактировано автором: 20 Марта, 2008 - 19:47:18)

 
 Top
valenok
Отправлено: 20 Марта, 2008 - 20:48:39
Post Id



Здесь могла бы быть ваша реклама


Покинул форум
Сообщений всего: 4574
Дата рег-ции: Июль 2006  
Откуда: Israel


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






-----
Truly yours, Sasha.
 
My status
 Top
KaJIbk
Отправлено: 22 Марта, 2008 - 11:35:11
Post Id


Новичок


Покинул форум
Сообщений всего: 1
Дата рег-ции: Март 2008  


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




У меня аналогичная проблема. Хотя я делаю не update, a select и у меня не mysql а mssql.
Однако все запросы, в которые динамически подставляются значения переменных, полученные из массива POST не возвращают результатов. В частности я передаю параметры user defined функции.
Указанный выше совет не помог и мне.
 
 Top
valenok
Отправлено: 22 Марта, 2008 - 12:35:12
Post Id



Здесь могла бы быть ваша реклама


Покинул форум
Сообщений всего: 4574
Дата рег-ции: Июль 2006  
Откуда: Israel


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




У вас аналогичное решение
этапы которого подробно описаны вот тут:

http://phpfaq.ru/debug


-----
Truly yours, Sasha.
 
My status
 Top
EuGen Администратор
Отправлено: 22 Марта, 2008 - 16:03:29
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




З раза в одной теме одна и та же ссылка.. куда мы катимся ... (*
(прошу прощения за офтоп, не сдержался)

(Отредактировано автором: 22 Марта, 2008 - 16:03:50)



-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB