php для каждого вывода из базы данных не отображается правильно - PullRequest
1 голос
/ 22 июля 2011

У меня есть база данных с множеством продуктов, и я пытаюсь вывести их. Некоторые товары имеют одинаковый товар, но разные размеры.

Проблема, с которой я сталкиваюсь, заключается в получении продуктов с одинаковым itemid в список выбора. Я могу вывести продукты в обычном режиме, но я хочу, чтобы все группы одного и того же продукта в списке выбора.

Вот ссылка на мой сайт с жестко закодированным списком товаров http://operationbraveheart.org.uk/jcart/.

и вот ссылка на вывод моего кода http://operationbraveheart.org.uk/jcart/testshop.php

Происходит следующее: вместо загрузки разных форм для каждого отображаемого продукта я получаю одну форму с огромным пустым списком выбора.

Я хочу сделать что-то подобное, но вместо жесткого кодирования, я хочу зациклить мысль о базе данных, если есть только один элемент с этим itemid, это нормальная форма, если есть более одного с тем же itemid, он идет в списке выбора.

Вот мой код, который должен выводить продукты

echo "<table border='0' id='gallery'>";

    while ($row = $result->fetchrow()) { 
        $superitem[$row['itemid']][] = $row;
    }

    foreach($superitem AS $subitem) {
        list($prodid,$item,$description,$price) = $subitem[0];

        if ($count % NUMCOLS == 0) echo "<tr>";  # new row
        echo '<td>';

        //Your normal code up until the select box...
        echo '<form method="post" action="" class="jcart">
                <fieldset>
                    <input type="hidden" name="jcartToken" value="'.$_SESSION['jcartToken'].'" />
                    <input type="hidden" name="my-item-id" value="2" />
                    <input type="hidden" name="my-item-price" value="19.50" />
                    <input type="hidden" name="my-item-url" value="http://yahoo.com" />';

        if(count($subitem) > 1) {
            echo '<li><select name="my-item-name" id="foo">';
            foreach($subitem AS $subsubitem) {
                echo "<option value='".$subsubitem['size']."'>".$subsubitem['size']."</option>";
            }
            echo "</select></li>";
        }
        else {
            echo '<input type="hidden" name="my-item-name" value="'.$item.'" />'; 
        }
        echo'<li>Price: $<span class="price">10.00</span></li>
                    <li>
                        <label>Qty: <input type="text" name="my-item-qty" value="1" size="3" /></label>
                    </li>
                </ul>

                <input type="submit" name="my-add-button" value="add to cart" class="button" />
            </fieldset>
        </form>';

        echo '</td>';
        $count++;
        $counter++;

        if ($count % NUMCOLS == 0) echo "</tr>\n";  # end row
    }
    if ($count % NUMCOLS != 0) {
       while ($count++ % NUMCOLS) echo "<td>&nbsp;</td>";
       echo "</tr>";
    }
    echo "</table>";

Вот моя структура таблицы и пример данных

  CREATE TABLE `shop` (
  `prodid` int(2) NOT NULL auto_increment,
  `itemid` int(2) NOT NULL default '0',
  `item` varchar(50) NOT NULL default '',
  `size` char(2) NOT NULL default '',
  `description` text NOT NULL,
  `image` varchar(50) NOT NULL default '',
  `price` float NOT NULL default '0',
  PRIMARY KEY  (`prodid`)
) 

INSERT INTO `shop` VALUES (1, 1, 'Key Ring', '', 'Key Ring: This can be personalised', '', 2);
INSERT INTO `shop` VALUES (2, 2, 'Tableware', '', 'Tableware: Coasters and Table Mats', '', 3);
INSERT INTO `shop` VALUES (3, 3, 'Braveheart Bear', '', '7" Braveheart Bear (choice of T-Shrt)', '', 9.99);
INSERT INTO `shop` VALUES (4, 4, 'Bravehart Bear', '', '9" Braveheart Bear (choice of T-Shirt)', '', 11.99);
INSERT INTO `shop` VALUES (5, 5, 'Wristband', '', 'Operation Braveheart wristband', '', 2);
INSERT INTO `shop` VALUES (6, 6, 'Mug', '', 'Standard mug', '', 7.99);
INSERT INTO `shop` VALUES (7, 7, 'A5 jotter', '', 'Various designs', '', 0.75);
INSERT INTO `shop` VALUES (8, 8, 'Operation Braveheart T-Shirt', 'S', 'Operation Braveheart T-Shirt.  All size in army green.', '', 6.99);
INSERT INTO `shop` VALUES (9, 8, 'Operation Braveheart T-Shirt', 'M', 'Operation Braveheart T-Shirt. All size in army green.', '', 7.99);
INSERT INTO `shop` VALUES (10, 8, 'Operation Braveheart T-Shirt', 'L', 'Operation Braveheart T-Shirt. All size in army green.', '', 8.99);
INSERT INTO `shop` VALUES (11, 8, 'Operation Braveheart T-Shirt', 'XL', 'Operation Braveheart T-Shirt. All size in army green.', '', 9.99);

Я сейчас добавил print_r ($ superitem); и база данных struct / data

1 Ответ

1 голос
/ 22 июля 2011

В вашем массиве товаров нет названных элементов. Вы заметите, что $row['itemid'] для вашего ключа массива выдает [] в выводе print_r, и в дочерних массивах, создаваемых строками, отсутствует подстрочный индекс ['size']:

        [0] => Array
            (
                [0] => 1
                [1] => Key Ring
                [2] => Key Ring: This can be personalised
                [3] => 2
            )

.... там нет элемента item_id и нет элемента size. Предположительно, 0 => 1 - это item_id, а 3 => 2 - это размер.

Итак, ваш код генерации формы работает правильно, но ваша выборка из базы данных не удалась.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...