Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: В тег Select (MySQL, PHP и HTML) не отображаются значения. Почему?
 
 автор: baston   (28.04.2010 в 21:18)   письмо автору
 
 

Есть таблица в MySQL, содержащая 15 категорий продуктов. Мне нужно выбрать их из таблицы и поместить в выпадающий список (тег select) на странице в форме.
Однако список получается пустым. Точнее, в нем не отображаются значения. Хотя они выбираются.
Пожалуйста, подскажите в чем причина такого поведения? Спасибо.
Выбираю и помещаю значения так:
<?php
//Подключаемся к серверу и БД
include "config.php";
//Формируем запрос к БД
$query "SELECT * FROM `product_cat`";
//Отправляем запрос
$res mysql_query($query);
//Проверяем успешность запроса
if(!$res) exit("Ошибка запроса: ".mysql_error());
//Проверяем наличие записей
if(mysql_num_rows($res)>0)
{
?>
<html>
<head>
  <title>Добавление нового продукта в БД</title>
</head>
<body>
<h2>Добавить продукт:</h2>
<form name="addproduct" action="addproduct.php" method="post">
<table>
  <tr>
    <td align=right>Наименование продукта:&nbsp;</td>
    <td><input type=text name=nameproduct size=50></td>
  </tr>
  <tr>
    <td align=right>Категория продукта:&nbsp;</td>
    <td><select name=productcat>
      <?php // В цикле выводим опции селекта
        
while($prod_cat mysql_fetch_array($res)) { ?>
          <option><?php $prod_cat['name_product_cat'?></option>
                <?php }} ?>
        </select></td>
  </tr>
</table>
</form>
</body>
</html>


P.S. При этом в таком коде все отображается:
<?php
//Подключаемся к серверу и БД
include "config.php";
//Формируем запрос к БД
$query "SELECT * FROM `product_cat`";
//Отправляем запрос
$res mysql_query($query);
//Проверяем успешность запроса
if(!$res) exit("Ошибка запроса: ".mysql_error());
//Проверяем наличие записей
if(mysql_num_rows($res)>0)
{
    echo 
"<select name=productcat>";
    
// В цикле выводим опции селекта
  
while($prod_cat mysql_fetch_array($res))
  {
    echo 
"<option>".$prod_cat['name_product_cat']."</option>";
  }
  echo 
"</select>";
}

  Ответить  
 
 автор: Лена   (28.04.2010 в 21:26)   письмо автору
 
   для: baston   (28.04.2010 в 21:18)
 

Ответила, а вы уже новый кусок кода добавили.

<?php
        
while($prod_cat mysql_fetch_assoc($res)) { ?>
          <option value = ""><?php $prod_cat['name_product_cat'?></option>
                <?php }} ?>
?>

Вроде как все верно...
В option value - ид категории вставьте, иначе как вы потом узнаете, какой элемент из списка выбран?
Ошибки какие-то выводятся на страницу?

  Ответить  
 
 автор: baston   (28.04.2010 в 21:32)   письмо автору
 
   для: Лена   (28.04.2010 в 21:26)
 

Нет, никаких ошибок не показывает, хотя у меня все выставлено для отображения ошибок и нотисов.
Дело в том, что второй вариант кода все отображает. Код одинаков и корректен. Почему такая петрушка, не понимаю.
За советы спасибо.

  Ответить  
 
 автор: baston   (28.04.2010 в 22:53)   письмо автору
 
   для: baston   (28.04.2010 в 21:18)
 

Решено. Оказалось, надо добавить оператор echo для вывода в option. А я почему-то понадеялся, что будет обычная подстановка в option.
Всем спасибо.

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования