使用 PDO prepare 和 bindParam 插入数据库表

新手上路,请多包涵

简单来说,有人可以解释我在这里做错了什么——我只是想用 prepare 和 bindParam 插入数据库,这是将 0 和 Null 插入所有字段。

 $sql = $db->prepare("INSERT INTO db_fruit VALUES (id=? ,type=? ,colour=?)");
$sql->bindParam(1, $newId);
$sql->bindParam(2, $type);
$sql->bindParam(3, $colour);
$sql->execute()

顺便说一句:这种方法一直为我工作更新等,但在这种情况下不适用于插入

原文由 gavin stanley 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 416
2 个回答

你的语法不正确,试试这个:

 $sql = $db->prepare("INSERT INTO db_fruit (id, type, colour) VALUES (? ,? ,?)");
$sql->bindParam(1, $newId);
$sql->bindParam(2, $name);
$sql->bindParam(3, $colour);
$sql->execute();

原文由 A.O. 发布,翻译遵循 CC BY-SA 3.0 许可协议

扩展 AO 的答案,以下内容也是有效的:

 $sql = $db->prepare("INSERT INTO db_fruit (id, type, colour) VALUES (? ,? ,?)");
$sql->execute(array($newId, $name, $color));

和:

 $sql = $db->prepare("INSERT INTO db_fruit (id, type, colour) VALUES (:id, :name, :color)");
$sql->execute(array('id' => $newId, 'name' => $name, 'color' => $color));

可能只是个人喜好,但我发现这种语法更简洁。

原文由 Sammitch 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏