function cart() {
if(isset($_GET['add_cart'])){
global $connect;
$ip = getIp();
$pro_id = $_GET['add_cart'];
$check_pro = "SELECT * FROM cart WHERE ip_add = '$ip' AND p_id = '$pro_id'" ;
$run_check = mysqli_query($connect, $check_pro);
if(mysqli_num_rows($run_check)>0){
echo "do a thing";
}else {
$insert_pro = "insert into cart (p_id,ip_add) values ('$pro_id','$ip')";
$run_pro = mysqli_query($connect, $insert_pro);
if($run_pro){
echo "<script>window.open('index.php','_self')</script>";
}
}
}
我很可能会丢失如此明显的东西,所以请先谢谢您。
答案 0 :(得分:0)
qty
列没有默认值,并且在插入新行时没有为其提供值。这将导致错误。您需要指定一个值,例如0
。
此外,由于p_id
是INT
列,因此您无需将值放在引号中。
$insert_pro = "insert into cart (p_id,ip_add, qty) values ($pro_id,'$ip', 0)";
但是更好的方法是使用准备好的语句来防止SQL注入。
$insert_pro = $connect->prepare("insert into cart (p_id,ip_add, qty) values (?, ?, 0)");
$insert_pro->bind_param("is", $pro_id, $ip);
$run_pro = $insert_pro->execute();