php – 无法执行插入查询?

前端之家收集整理的这篇文章主要介绍了php – 无法执行插入查询?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

你能帮我解决这个问题吗?我试图将数据插入我的数据库,而不是插入die()输出;出现

PHP
    if (isset($_GET['submit'])) {
        $item_code = MysqLi_real_escape_string($conn,$_GET['item_code']);
        $item_name = MysqLi_real_escape_string($conn,$_GET['item_name']);
        $supplier = MysqLi_real_escape_string($conn,$_GET['supplier_name']);
        $brand = MysqLi_real_escape_string($conn,$_GET['brand_name']);
        $quantity = MysqLi_real_escape_string($conn,$_GET['quantity']);
        $unit = MysqLi_real_escape_string($conn,$_GET['unit_name']);
        $price = MysqLi_real_escape_string($conn,$_GET['price']);
        $item_type = MysqLi_real_escape_string($conn,$_GET['type_name']);
        $category = MysqLi_real_escape_string($conn,$_GET['cat_name']);

        if ($item_code == '' || $item_name == '' || $supplier == '' || $brand == '' ||
            $quantity == '' ||
            $unit == '' ||
            $price == '' ||
            $item_type == '' ||
            $category == ''
        ) {
            header("Location: item.PHP?attempt=empty");
        } else {
            $sql = MysqLi_query($conn,"INSERT INTO itemlist (item_name,supplier_name,brand_name,quantity,unit_name,price,type_name,cat_name)    values('$item_name','$supplier','$brand','$quantity','$unit','$price','$item_type','$category')")

            or die("Could not execute the insert query.");
            header("Location: item.PHP?attempt=saved");
        }
    } 
?>
最佳答案
我只注意到一些事情:

>为什么使用GET方法传递数据而不是POST?
>您可以使用empty()而不是==”
>您可以尝试prepared statement,而不是转义和清理每个提交的数据
> $_GET [‘item_code’]的目的是什么?你没有在插入中使用它,但它在你的if()条件下.

假设您将表单从GET更改为POST方法

if (isset($_POST['submit'])) {

    if(empty($_POST['item_code']) || empty($_POST['item_name']) || empty($_POST['supplier_name']) || empty($_POST['brand_name']) || empty($_POST['quantity']) || empty($_POST['unit_name']) || empty($_POST['price']) || empty($_POST['type_name']) || empty($_POST['cat_name'])){

        header("Location: item.PHP?attempt=empty");

    } else {

        $stmt = $conn->prepare("INSERT INTO itemlist (item_code,item_name,cat_name) VALUES (?,?,?)");
        $stmt->bind_param("sssssssss",$_POST['item_code'],$_POST['item_name'],$_POST['supplier_name'],$_POST['brand_name'],$_POST['quantity'],$_POST['unit_name'],$_POST['price'],$_POST['type_name'],$_POST['cat_name']);
        $stmt->execute();
        $stmt->close();

        header("Location: item.PHP?attempt=saved");
    }
} 

请记住,一个空数据将进入if()条件并执行标题(“Location:item.PHP?attempt = empty”);.

猜你在找的MySQL相关文章