如何更新表中的多行

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何更新表中的多行相关的知识,希望对你有一定的参考价值。

我正在使用phpmysql制作在线商店购物车。而现在我正在开车。基本上到现在为止,我可以从数据库中检索数据并将其显示在购物车中,就像这张图片一样:

现在我正在努力更新产品数量。例如,用户必须能够设置产品1到2,产品2到3和产品3到4的数量。

因此,必须有多个查询,因为每个产品都有唯一的产品ID。

所以我做的是这样的:

<select name='quantities[]'>
<option value='1'>1</option>
<option value='2'>2</option>
<option value='3'>3</option>
<option value='4'>4</option>
<option value='5'>5</option>
</select>

这种形式的行为是这样的:

$cart_id = $_GET['cart_id'];
if(isset($_POST['update'])){
    foreach($_POST['quantities'] as $quantities)
    {
        $insert_qty = "UPDATE cart SET qty = '$quantities' WHERE cart_id = '$cart_id'";
        $run_qty = mysqli_query($con,$insert_qty);
        if($run_qty)
        {
            echo '<META HTTP-EQUIV="Refresh" Content="0; URL=cart.php">';    
        }else{
            die(mysqli_error($con));
        }
    }
}

但是这个代码的问题在于它只获取最后一个产品的最后数量,并将整个购物车项目更新为该数字。

例如,如果您将上一个产品的数量设置为5,它最终会将数字5设置为该购物车中现有的所有产品。

所以我的问题是如何才能正确更新购物车,以便每个产品都有一个单独的数量。

我真的很感激这个问题的任何想法,建议或解决方案,

提前致谢...

这也是我检索数据的方式(仅供查看):

$get_add = "SELECT * FROM cart WHERE cart_id = '$cart_id'";
$run_add = mysqli_query($con,$get_add);
$cart_items = [];
$total_price_to_pay = 0;
while ($row_results = mysqli_fetch_array($run_add)){
    $item = array(
        'table_id' => $row_results['table_id'],
        'cart_id' => $row_results['cart_id'],
        'pro_id' => $row_results['product_id'],
        'pro_title' => $row_results['product_title'],
        'pro_price' => $row_results['product_price'],
        'pro_img' => $row_results['product_image'],
        'pro_supplier' => $row_results['product_supplier'],
        'qty' => $row_results['qty'],
        'cart_ip' => $row_results['cart_ip'],
        'pro_total' => $row_results['qty']*$row_results['product_price'],
    );
    $total_price_to_pay +=  $row_results['qty']*$row_results['product_price'];
    $cart_items[] = $item;
}
foreach ($cart_items as $cart) {
        echo $cart['pro_title'] etc ;
}
答案

您需要发布所有数量的product_id(请将value="<?php echo $item['pro_id']; ?>"替换为您的实际变量,可以在每个购物车项目/产品的隐藏字段中设置正确的product_id,或者如果它已经存在,那么您可以删除此隐藏字段并使用它代替):

<input type="hidden" name="product_ids[]" value="<?php echo $item['pro_id']; ?>" />
<select name='quantities[]'>
    <option value='1'>1</option>
    <option value='2'>2</option>
    <option value='3'>3</option>
    <option value='4'>4</option>
    <option value='5'>5</option>
</select>

然后在行动方面在您的更新查询中使用此product_id(如果product_id已经不存在,还需要在数据库表中进行更改):

$cart_id = $_GET['cart_id'];
if(isset($_POST['update'])){
    foreach($_POST['quantities'] as $index => $quantities)
    {
        $insert_qty = "UPDATE cart SET qty = '$quantities' WHERE cart_id = '$cart_id' AND product_id = '".$_POST['product_ids'][$index]."'";
        $run_qty = mysqli_query($con,$insert_qty);
        if($run_qty) {
            echo '<META HTTP-EQUIV="Refresh" Content="0; URL=cart.php">';    
        } else {
            die(mysqli_error($con));
        }
    }
}

希望,它会解决你的问题......

以上是关于如何更新表中的多行的主要内容,如果未能解决你的问题,请参考以下文章

如何更新表中的多行

更新单列中的多行

向表中插入多行 - Access

当必须用单行指定行时,表中的 Markdown 多行代码块

使用 System.Transaction 如何更新实体框架中的多行

如何在一个表中显示多行,另一表中的一行显示为单行