PHP在json对象发布的mysql中插入数据

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (189)

我想通过PHP将一些数据从jQueryMobil.listwidget发送到mysql数据库。

我得到并发布我的listitems,如下所示:

function getItems()
{ 
        var listview_array = new Array();
        $( "#itemList li" ).each(function(index) {
            listview_el = new Object();
            listview_el.id = index;
            listview_el.name=$(this).text();
            listview_el.owner="owner";
            listview_array.push(listview_el);
        });
        var stringifyObject = JSON.stringify(listview_array);
        //alert(stringifyObject);
        $.ajax({
            type: "POST",
            dataType: 'json',
            url: "insert.php",
            data: { mydata: stringifyObject },
        });
        //showItems();

}

我想将我的json-object添加到存在的mysql数据库/表中。根据我的要求,我的数据已发送,但if(prepStmnt)从未成功。

 <?php

    $con = new mysqli($servername, $username, $password, $dbname);
    if (!$con) {
      die('Could not connect: ' . mysqli_error($con));
    }

    echo "preps";
    if($preparedStatement = $con->prepare('INSERT INTO Einkaufsliste (item, owner) VALUES (:name, :owner)')){
        $preparedStatement->execute(json_decode($_POST["mydata"], true));
        $preparedStatement->close();
        echo "done";
    };

    $con->close();
    ?> 

你能告诉我为什么数据库中没有数据存储吗?

提问于
用户回答回答于

库MySQLi不支持命名的参数。

if($preparedStatement = $con->[...snip...] (:name, :owner)')){
                                            ^^^^^^^^^^^^^

这在MySQLi中是完全非法的,因此您的准备失败,而其他所有内容都落在脚本的末尾,因为您没有错误检查。

$prepare = $con->prepare(...);
if (!$prepare) {
   die(mysqli_error($con));
}

一个适当的mysqli准备声明将是

$stmt = $con->prepare('INSERT ... VALUES (?, ?)');

注意?占位符。

决不EVER假设你的查询将suceed。即使你的sql实际上是正确的,但是查询失败的方法几乎无穷无尽。总是假设失败,检查失败,并将成功视为一个惊喜。

扫码关注云+社区

领取腾讯云代金券