【问题标题】:how to check whether quantity entered on form is greater than the stock quantity in database如何检查表格中输入的数量是否大于数据库中的库存数量
【发布时间】:2014-04-11 20:08:39
【问题描述】:

试图检查用户在表单上输入的数量是否大于库存。如果是,那么它应该在表单上将数量设置为 STOCK VALUE。

if (isset($_SESSION["cart_array"]))
{ 
    if (isset($_POST['item_to_adjust']) && $_POST['item_to_adjust'] != "") {
    // execute some code
    $item_to_adjust = $_POST['item_to_adjust'];
    $quantity = $_POST['quantity'];
    $quantity = preg_replace('#[^0-9]#i', '', $quantity); // filter everything   but       numbers
    if ($quantity >= 100) { $quantity = 99; }
    if ($quantity < 1) { $quantity = 1; }
    if ($quantity == "") { $quantity = 1; }

    $sqlquan = mysql_query("SELECT * FROM products WHERE id='$item_id' LIMIT 1");
        while ($row = mysql_fetch_array($sqlquan)) {
            $item_id= $row["id"];
            $stock= $row["stock"];
        }
            if ($quantity > $stock)
        {echo "much";
        $quantity=$stock;}

    $i = 0;
        foreach ($_SESSION["cart_array"] as $each_item) { 
              $i++;
              while (list($key, $value) = each($each_item)) {
                  if ($key == "item_id" && $value == $item_to_adjust) {
                      // That item is in cart already so let's adjust  its quantity using array_splice()
                      array_splice($_SESSION["cart_array"], $i-1, 1, array(array("item_id" => $item_to_adjust, "quantity" => $quantity)));
                  } // close if condition
              } // close while loop
    } // close foreach loop
}
}

问题是我的购物车中有 2 件商品。第一个的库存值为 15,第二个的库存值为 23。如果我为第一个产品输入的数量大于 15,则效果很好(将数量设置为 15)。但是,如果我为第二个产品输入一个大于 15 但小于 23 的值,它会与第一个产品的库存值进行比较并再次重置为 15。

【问题讨论】:

  • 您的问题是什么?此代码如何未按预期执行?有任何错误消息吗?
  • 问题是我在购物车中有 2 件商品。第一个的库存值为 15,第二个的库存值为 23。如果我为第一个产品输入的数量大于 15,则效果很好(将数量设置为 15)。但是如果我为第二个产品输入一个大于 15 但小于 23 的值,它会与第一个产品的库存值进行比较并再次重置为 15。
  • @user3525190 $_POST['quantity'] 似乎没有绑定到任何项目,所以您首先需要制作一个与所有项目对应的数量数组。
  • 对不起,我无法显示整个代码。很多行。
  • 您可以随时编辑原始问题以添加大量新代码或新信息。如果您有小代码 sn-ps,您可以使用反引号 like this 将它们作为代码显示在注释中。

标签: php stock


【解决方案1】:

相当多地清理了您的代码。希望这行得通。

if(isset($_SESSION["cart_array"])) {
    if(isset($_POST['item_to_adjust']) && !empty($_POST['item_to_adjust'])) {
        $item_to_adjust = $_POST['item_to_adjust'];
        $quantity = preg_replace('#[^0-9]#i', '', $_POST['quantity']); // filter everything but numbers
        if ($quantity >= 100) $quantity = 99;
        if (empty($quantity) || $quantity < 1) $quantity = 1;

        $sqlquan = mysql_query("SELECT * FROM products WHERE id='$item_to_adjust' LIMIT 1"); // You previously used id='$item_id', I think you meant $item_to_adjust

        // Since you have limited your query to only have 1 result, there is no need to use a while loop
        // also note in your original code the while loop was closed prematurely.
        $row = mysql_fetch_array($sqlquan);
        // No need to create new variables when $row is accessible directly

        if($quantity > $row["stock"]) {
            echo "Requested Quantity exceeds currently available Stock.<br>";
            $quantity = $row["stock"];
            echo "Quantity set to maximum available stock of ".$row["stock"]."<br>";
        }

        foreach($_SESSION["cart_array"] as &$each_item) {   // Referenced variable &$each_item so you do not have to use complicated array functions
            if($each_item['item_id'] == $item_to_adjust) {
                $each_item['quantity'] = $quantity;
                break; // Terminates the foreach loop
            }
        } // close foreach loop
    } else {
        echo("Invalid Item ID");
    }
}

【讨论】:

  • @user3525190 如果不起作用,请提前道歉。它的早上 5 点 17 分从那以后 24 小时都醒着。
猜你喜欢
  • 2017-12-28
  • 2017-05-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多