Вставка двух элементов массива один за другим в таблицу БД - PullRequest
1 голос
/ 05 февраля 2012

У меня есть такая HTML-форма:

...
<input type="text" id="color"  name="color" value="" placeholder="Color" />
<input type="text" name="size" id="size" value="" placeholder="Size" />
... 

Во время отправки формы я проверяю, разделяются ли значения входных данных запятыми.

Если да, то делать что-то подобное:

  • Допустим, пользователь ввел 1 цвет: черный и несколько размеров: 42, 43, 44. Код будет вставлен 3 раза с разными размерами, но все остальные значения будут одинаковыми

  • Допустим, пользователь ввел несколько цветов: черный, желтый и 1 размер: 42. Код будет вставлен 2 раза с разными цветами, но все остальные значения будут одинаковыми

Вопрос

Что делать, если пользователь ввел несколько цветов и несколько размеров. Нечто подобное, цвета: черный, оранжевый, синий и размеры: 45,46,48. Код должен быть вставлен 9 раз: черный - 45, черный - 46 ... синий-48. Как мне это сделать?

Вот код PHP:

public function add() {
        if ($_POST['formID'] == 'add_form') {
            $stmt = $this->db->prepare("INSERT INTO `items` 
          (`refno`, `color`, `size`, `qt`, `stackno`, `notes`, `price`, `add_date`)
          VALUES (?, ?, ?, ?, ?, ?, ?, NOW())") or die($db->error);
            $count = array();
            $size_arr = explode(",", $_POST['size']);
            $color_arr = explode(",", $_POST['color']);
            $count['size'] = count($size_arr);
            $count['color'] = count($color_arr);
            if ($count['color'] > 1) {
                foreach ($color_arr as $color) {
                    $stmt->bind_param("ssiiisi", $_POST['refno'], $color, $_POST['size'], $_POST['qt'], $_POST['stackno'], $_POST['notes'], $_POST['price']) or die($stmt->error);
                    $stmt->execute() or die($stmt->error);
                }
            }
            if ($count['size'] > 1) {
                foreach ($size_arr as $size) {
                    $stmt->bind_param("ssiiisi", $_POST['refno'], $_POST['color'], $size, $_POST['qt'], $_POST['stackno'], $_POST['notes'], $_POST['price']) or die($stmt->error);
                    $stmt->execute() or die($stmt->error);
                }
            } else {
                $stmt->bind_param("ssiiisi", $_POST['refno'], $_POST['color'], $_POST['size'], $_POST['qt'], $_POST['stackno'], $_POST['notes'], $_POST['price']) or die($stmt->error);
                $stmt->execute() or die($stmt->error);
            }
            $stmt->close();
            $this->ajax->respond("nb", "Successfuly added", 1);
        }
    }

1 Ответ

1 голос
/ 05 февраля 2012

Метод грубой силы с двумя циклами for должен работать

foreach ($color_arr as $color) {
     foreach($size_arr as $size) {
          // insert into the database
     }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...