Intereting Posts
как использовать php с ini-файлами Как отправлять и получать данные из MySQL для определенного id из приложения для Android пустая веб-страница с d3.json (bardata.php), но работает с d3.json (bardata.json) Экранирующая строка для использования в регулярном выражении Повторяющийся ключ не запускает исключение, генерирующее PDO для составного ключа в простом примере Как следует распространять изменения в объектах MVC? Как удалить таблицу MSSQL Datetime GETDATE () Столбцы, если они являются старыми или старыми с использованием PHP как удалить повторяющиеся значения в таблице mysql Как подключить два или несколько файлов и отправить почту в PHP Запуск php-скрипта через ajax, но только если он еще не запущен PHP MVC / ORM Framework, которые являются Hyper PHP (HipHop) Ready в php5, хотите отправить электронную почту в другом процессе Как запустить скрипт оболочки с живой обратной связью с PHP? PHP Неустранимая ошибка: Class 'AMQPConnection' не найден Создание уникальных кодов в PHP / MySQL?

Как вставить данные упорядочения из многомерного массива

<?php ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// // Section 5 (render the cart for the user to view on the page) ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// $cartOutput = ""; $cartTotal = ""; $pp_checkout_btn = ''; $checkout_btn = ''; $product_id_array = ''; if (!isset($_SESSION["cart_array"]) || count($_SESSION["cart_array"]) < 1) { $cartOutput = "<h2 align='center'>Your shopping cart is empty</h2>"; } else { // Start PayPal Checkout Button $pp_checkout_btn .= '<form action="http://chenlikpharmacy.freeserver.me/order_list.php" method="post"> <input type="hidden" name="cartOutput" id="cartOutput" value = "<?php echo $cartOutput; ?> '; // Start the For Each loop $i = 0; foreach ($_SESSION["cart_array"] as $each_item) { $item_id = $each_item['item_id']; $sqlCommand = "SELECT * FROM products WHERE id='$item_id' LIMIT 1"; $sql = mysqli_query($myConnection,$sqlCommand); while ($row = mysqli_fetch_array($sql)) { $product_name = $row["product_name"]; $price = $row["price"]; $details = $row["details"]; } $pricetotal = $price * $each_item['quantity']; $cartTotal = $pricetotal + $cartTotal; setlocale(LC_MONETARY, "ms_MY"); $pricetotal = money_format("%10.2n", $pricetotal); // Dynamic Checkout Btn Assembly $x = $i + 1; $pp_checkout_btn .= '<input type="hidden" name="item_name[]" value="' . $product_name . '"> <input type="hidden" name="amount[]" value="' . $price . '"> <input type="hidden" name="quantity[]" value="' . $each_item['quantity'] . '"> '; // Create the product array variable $product_id_array .= "$item_id-".$each_item['quantity'].","; // Dynamic table row assembly $cartOutput .= "<tr>"; $cartOutput .= '<td><a href="product.php?id=' . $item_id . '">' . $product_name . '</a><br /><img src="inventory_images/' . $item_id . '.jpg" alt="' . $product_name. '" width="40" height="52" border="1" /></td>'; $cartOutput .= '<td>' . $details . '</td>'; $cartOutput .= '<td>RM ' . $price . '</td>'; $cartOutput .= '<td><form action="cart.php" method="post"> <input name="quantity" type="text" value="' . $each_item['quantity'] . '" size="1" maxlength="2" /> <input name="adjustBtn' . $item_id . '" type="submit" value="change" /> <input name="item_to_adjust" type="hidden" value="' . $item_id . '" /> </form></td>'; //$cartOutput .= '<td>' . $each_item['quantity'] . '</td>'; $cartOutput .= '<td>' . $pricetotal . '</td>'; $cartOutput .= '<td><form action="cart.php" method="post"><input name="deleteBtn' . $item_id . '" type="submit" value="X" /><input name="index_to_remove" type="hidden" value="' . $i . '" /></form></td>'; $cartOutput .= '</tr>'; $i++; } setlocale(LC_MONETARY, "ms_MY"); $cartTotal = money_format("%10.2n", $cartTotal); $cartTotal = "<div style='font-size:18px; margin-top:12px;' align='right'>Cart Total : ".$cartTotal." MYR</div>"; // Finish the Paypal Checkout Btn $pp_checkout_btn .= '<input type="hidden" name="custom" value="' . $product_id_array . '"> <input type="submit" type="button" name="submit"> </form>'; } ?> 

Вышеупомянутый исходный код, который я изучил в Интернете, для создания многомерного массива и отправки в paypal для обработки. Теперь я стараюсь избегать paypal и хочу вставить данные, представленные в мои новые заказы базы данных. Для этой цели я создал строку (id (primary, auto increment), product_name, price, quantity, date_added), но мне не удалось вставить данные в нее ….

моя попытка ниже

 <?php // This file is www.developphp.com curriculum material // Written by Adam Khoury January 01, 2011 // http://www.youtube.com/view_play_list?p=442E340A42191003 session_start(); // Start session first thing in script // Script Error Reporting error_reporting(E_ALL); ini_set('display_errors', '1'); // Connect to the MySQL database include "storescripts/connect_to_mysqli.php"; ?> <?php // Parse the form data and add inventory item to the system if (isset($_POST['cartOutput'])) { $product_name=mysqli_real_escape_string($myConnection,$_POST[' . $product_name . ']); $price=mysqli_real_escape_string($myConnection,$_POST[' . $price . ']); $quantity=mysqli_real_escape_string($myConnection,$_POST[$each_item['quantity']]); $date = date('d/m/Y', time()); $sqlCommand = ""INSERT INTO orders (product_name, price, quantity, date_added) VALUES('" . $_POST[$product_name] . "','" . $_POST[$price] . "','" . $_POST[$each_item['quantity']] . "', now())";  $sql = mysqli_query($myConnection,$sqlCommand) or die (mysqli_error()); $stmt = $mysqli->prepare($sql); $countArray = count($_SESSION["cart_array"); for ($i = 0; $i < $countArray; $i++) { $stmt->bind_param('ssd', $array[$product_name][$i], $array[$price][$i], $array[$each_item['quantity']][$i],$array[$date][$i]); $stmt->execute(); } echo $sql  ; exit(); } ?> 

ПОМОЩЬ ~~~ Мне нужно знать, что мне добавить, если (isset ($ _ POST ['cartOutput'])) {чтобы получить дату … я действительно новичок. Мне нужно волшебство ……

Мой пример использует PDO, но я думаю, что вы поняли идею. Также вы должны перейти в PDO или MYSQLI вместо mysql

пример:

 <?php // pdo example $sql = 'INSERT INTO table (field1, field2, field3) VALUES (:value1, :value2, :value3)'; // $dbh is pdo connection $insertTable = $dbh->prepare($sql); $countArray = count($array); for ($i = 0; $i < $countArray; $i++) { $insertTable->bindParam(':value1', $array['value1'][$i], PDO::PARAM_INT); // if value is int $insertTable->bindParam(':value2', $array['value2'][$i], PDO::PARAM_STR); // if value is str $insertTable->bindParam(':value3', $array['value3'][$i], PDO::PARAM_STR); $insertTable->execute(); } ?> 

Формат входных имен

Я вижу, что вы делаете это: amount_' . $x . ' amount_' . $x . ' amount_' . $x . ' ваш массив будет выглядеть следующим образом:

 [amount_0] => 100 [amount_1] => 200 [amount_2] => 1 [quantity] => 10 [quantity] => 20 [quantity] => 1 

но если ваша amount[] записи amount[] массив будет выглядеть так:

 [amount] => Array ( [0] => 100 [1] => 200 [2] => 1 ) [quantity] => Array ( [0] => 10 [1] => 20 [2] => 1 

Последний вариант значительно облегчает чтение массива.

Пример MYSQLI

 <?php $sql = 'INSERT INTO table (field1, field2, field3) VALUES (?, ?, ?)'; $stmt = $mysqli->prepare($sql); $countArray = count($array); for ($i = 0; $i < $countArray; $i++) { $stmt->bind_param('ssd', $array['value1'][$i], $array['value2'][$i], $array['value3'][$i]); $stmt->execute(); } ?> 

Поскольку вы можете видеть, что перед параметрами стоит ssd , это типы, которые имеют 4 типа:

  • i = intenger
  • s = строка
  • d = двойной
  • b = blob

Вы должны всегда определять это.

редактировать

Вы должны использовать это:

 <?php // Parse the form data and add inventory item to the system if (isset($_POST['cartOutput'])) { $sql= 'INSERT INTO orders (product_name, price, quantity, date_added) VALUES(?,?,?, NOW())'; $stmt = $myConnection->prepare($sql); $countArray = count($_POST["item_name"); for ($i = 0; $i < $countArray; $i++) { $stmt->bind_param('sss', $_POST['item_name'][$i], $_POST['amount'][$i], $_POST['quantity'][$i]); $stmt->execute(); } echo $sql ; exit(); } ?> 

1) Ваше действие формы для pp_checkout_btn по-прежнему показывает «paypal web». Я думаю, что это просто опечатка, поэтому, пожалуйста, перейдите и измените это в первую очередь.

2) Кроме того, в вашем заявлении вставки можно использовать небольшие настройки. Просьба представить результаты для следующих двух утверждений для создания точной инструкции вставки:

 print_r($_POST) // once the data has been posted echo $sql // place this just before calling exit 

– ищущие01

Я думаю, что ваш код вставки должен быть ниже
$sql = mysql_query("INSERT INTO orders (product_name, price, quantity, date_added) VALUES('" . $_POST[$product_name] . "','" . $_POST[$price] . "','" . $_POST[$each_item['quantity']] . "', now())") or die (mysql_error());

Редактировать:
Кроме того, утверждение внутри цикла должно быть
$stmt->bind_param('ssd', $array[$product_name][$i], $array[$price][$i], $array[$each_item['quantity']][$i]);

Вот код, к которому вы должны обратиться:

 <?php // This file is www.developphp.com curriculum material // Written by Adam Khoury January 01, 2011 // http://www.youtube.com/view_play_list?p=442E340A42191003 session_start(); // Start session first thing in script // Script Error Reporting error_reporting(E_ALL); ini_set('display_errors', '1'); // Connect to the MySQL database include "storescripts/connect_to_mysqli.php"; ?> <?php // Parse the form data and add inventory item to the system if (isset($_POST['cartOutput'])) { $product_name=$_POST[$product_name]; $price=$_POST[$price]; $quantity=$_POST[$each_item['quantity']]; $sqlCommand = "INSERT INTO orders (product_name, price, quantity, date_added) VALUES('" . $_POST[$product_name] . "','" . $_POST[$price] . "','" . $_POST[$each_item['quantity']] . "', now())";  $sql = mysqli_query($myConnection,$sqlCommand) or die (mysqli_error()); $stmt = $mysqli->prepare($sql); $countArray = count($_SESSION["cart_array"]); for ($i = 0; $i < $countArray; $i++) { $stmt->bind_param('ssd', $array[$product_name][$i], $array[$price][$i], $array[$each_item['quantity']][$i]); $stmt->execute(); } echo $sql; exit(); } ?> 

Чтобы получить дату:

 $date = date('d/m/Y', time()); 

Попробуйте это, а затем посмотрите, работает ли оно.