我想更新一个表,但我一直收到错误: 在boolean
上调用成员函数bind_param()我做错了什么? 在我的数据库设置中如下所示:
'{"name":"Product Slider","product_name":"","product":["240","375","5555"],"limit":"5","width":"600","height":"400","loop":"1","auto":"1","pager":"1","pause":"3000","speed":"800","status":"1"}'
我尝试更新:
$sliderSql=$con->prepare("UPDATE oc_module SET setting = '{'name':'Product Slider','product_name':'','product':[?],'limit':'5','width':'600','height':'400','loop':'1','auto':'1','pager':'1','pause':'3000','speed':'800','status':'1'}' WHERE oc_module.module_id = 95");
$param="'".$calcSlider[0]."','".$laptopSlider[0]."','".$serverSlider[0]."'";
$sliderSql->bind_param("s",$param);
答案 0 :(得分:1)
SQL中的引号是错误的。 JSON中的单引号正在终止字符串。 JSON中的引号必须是双引号。由于它们嵌入在字符串文字中,因此您需要将它们转义。
$sliderSql=$con->prepare("UPDATE oc_module SET setting = '{\"name\":\"Product Slider\",\"product_name\":\"\",\"product\":[?],\"limit\":\"5\",\"width\":\"600\",\"height\":\"400\",\"loop\":\"1\",\"auto\":\"1\",\"pager\":\"1\",\"pause\":\"3000\",\"speed\":\"800\",\"status\":\"1\"}' WHERE oc_module.module_id = 95");
但还有另一个问题。您不能在字符串文字中放置?
参数 - 它们只能在允许值表达式的地方使用。
如果使用单独的变量,使用json_encode()
转换为JSON,会更容易。
$setting = json_encode(array(
"name" => "Product Slider",
"product_name" => "",
"product" => array($calcSlider[0], $laptopSlider[0], $serverSlider[0]),
"limit" => "5",
"width" => "600",
"height" => "400",
"loop" => "1",
"auto" => "1",
"pager" => "1",
"pause" => "3000",
"speed" => "800",
"status" => "1"));
$sliderSql = $con->prepare("UPDATE oc_module SET setting = ?");
$sliderSql->bind_param("s", $setting);