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 :: Не удается реализовать работу с БД

 PHP.SU

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


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

> Без описания
lawer85
Отправлено: 25 Августа, 2013 - 18:25:57
Post Id


Частый гость


Покинул форум
Сообщений всего: 189
Дата рег-ции: Янв. 2013  


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




Вот форма добавления товара в БД

CODE (html):
скопировать код в буфер обмена
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4.         <title>Заголовок</title>
  5. </head>
  6. <body>
  7.         <form name="myform" action="dobavlenie_tovara.php" method="post">
  8.                 <table>
  9.                         <tr>
  10.                                 <td><b>Добавить новый товар</b></td>
  11.                         </tr>
  12.                         <tr>
  13.                                 <td>Название товара:</td>
  14.                                 <td>
  15.                                         <input type="text" name="name_of_good" />
  16.                                 </td>
  17.                         </tr>  
  18.                         <tr>
  19.                                 <td>Краткое описание:</td>
  20.                                 <td>
  21.                                         <input type="text" name="short_description" />
  22.                                 </td>
  23.                         </tr>  
  24.                         <tr>
  25.                                 <td>Полное описание:</td>
  26.                                 <td>
  27.                                         <textarea rows="10" cols="60" name="full_description"></textarea>
  28.                                 </td>
  29.                         </tr>
  30.                         <tr>
  31.                                 <td>
  32.                                         <input type="submit" value="Отправить" name="Отправить" />
  33.                                 </td>
  34.                         </tr>                          
  35.                 </table>
  36.         </form>
  37. </body>
  38. </html>


обработчик

PHP:
скопировать код в буфер обмена
  1. <?PHP
  2.  
  3.         if (isset($_REQUEST["Отправить"])) {
  4.         $mysqli = new mysqli("localhost", "root", "", "bd");
  5.         $mysqli->query("SET NAMES 'utf8'");
  6.         $mysqli->query("INSERT INTO `bd`.`товары` (`id`, `Название товара`, `Краткое описание`, `Полное описание`, `Число купивших товар`) VALUES (NULL, '".$_REQUEST["name_of_good"]."', '".$_REQUEST["short_description"]."', '".$_REQUEST["full_description"]."', '0')");
  7.         $mysqli->close();
  8.         }
  9. ?>


Запись в таблицу заказы не добавляется.
 
 Top
armancho7777777 Супермодератор
Отправлено: 25 Августа, 2013 - 18:33:46
Post Id



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


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


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




lawer85 пишет:
`Название товара`, `Краткое описание`, `Полное описание`, `Число купивших товар`

У Вас там реальные поля такие ?
 
 Top
lawer85
Отправлено: 25 Августа, 2013 - 18:35:25
Post Id


Частый гость


Покинул форум
Сообщений всего: 189
Дата рег-ции: Янв. 2013  


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




armancho7777777 пишет:
lawer85 пишет:
`Название товара`, `Краткое описание`, `Полное описание`, `Число купивших товар`

У Вас там реальные поля такие ?


Да.
 
 Top
armancho7777777 Супермодератор
Отправлено: 25 Августа, 2013 - 18:39:04
Post Id



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


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


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




Ну Вы даёте ))
Переименуйте для начала.
И без пробельных символов.
Можете заменить их на нижнее подчёркивание.
 
 Top
lawer85
Отправлено: 25 Августа, 2013 - 18:40:18
Post Id


Частый гость


Покинул форум
Сообщений всего: 189
Дата рег-ции: Янв. 2013  


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




если на странице ../dobavlenie_tovara.php не проверять существование $_REQUEST["Отправить"] и подставить в запрос конкретные данные, то запись будет добавлена. Видимо скрипт почему-то считает, что переменная $_REQUEST["Отправить"] не существует, хотя это не так, проверить можно через print_r($_REQUEST)
 
 Top
armancho7777777 Супермодератор
Отправлено: 25 Августа, 2013 - 18:41:30
Post Id



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


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


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




lawer85 пишет:
if (isset($_REQUEST["Отправить"])) {

Замените хотя бы на:
PHP:
скопировать код в буфер обмена
  1. if($_SERVER['REQUEST_METHOD'] == 'POST') {

(Отредактировано автором: 25 Августа, 2013 - 18:44:17)

 
 Top
lawer85
Отправлено: 25 Августа, 2013 - 18:51:26
Post Id


Частый гость


Покинул форум
Сообщений всего: 189
Дата рег-ции: Янв. 2013  


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




Заменил, но при добавлении записи, поля в БД пустые
(Добавление)
Странно данные полей из формы не пустые, а почему тогда поля записи в БД пустые???

(Отредактировано автором: 25 Августа, 2013 - 18:52:00)

 
 Top
lawer85
Отправлено: 25 Августа, 2013 - 22:45:31
Post Id


Частый гость


Покинул форум
Сообщений всего: 189
Дата рег-ции: Янв. 2013  


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




Нашел проблему. Дело было в кодировке

Если конкретнее то я изменил сам файл откуда отправлялась форма на utf8 без ВОМ в notepad++ и саму кодировку в денвере сделал по умолчанию в utf8 для этого по след пути /usr/local/apache/conf/ нашел файл httpd.conf и строку AddDefaultCharset windows-1251 поменял на AddDefaultCharset utf-8

(Отредактировано автором: 25 Августа, 2013 - 22:49:46)

 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB