php - 使用 PDO 向表中插入大量变量

标签 php mysql pdo

我有一个包含大约 25 个输入字段的大表单。

我试图将它们插入到我的表中,而我知道的唯一方法是使用以下...

$count = $dbh->exec("INSERT INTO directory(field1, field2) VALUES (':value1', ':value2')");

因为我有这么多的帖子变量,有没有比在我的查询中输入每个人更好的方法呢?

最佳答案

动态准备好的查询

您可以从 $_POST 数组动态构建查询:

但是,永远不要相信用户输入,这意味着您不能相信 $_POST 中的数据会包含有效的列名。

<强>1。清理帖子数据

您可以定义一个列入白名单的列名数组$whitelist = array('field1', 'field2', ...),然后使用:

$data = array_intersect_key($_POST, array_flip($whitelist));

找到白名单列和 $_POST 数组之间的交集。 (感谢@BillKarwin)

<强>2。构建查询

private function buildInsertSql($data, $table) {
    $columns = "";  
    $holders = "";  
    foreach ($data as $column => $value) {  
       $columns .= ($columns == "") ? "" : ", ";  
       $columns .= $column;  
       $holders .= ($holders == "") ? "" : ", ";  
       $holders .= ":$column";  
    }  
    $sql = "INSERT INTO $table ($columns) VALUES ($holders)";  
    return $sql; 
}

这将为您提供以下形式的 SQL 语句:

$sql = INSERT INTO directory (field1, field2) VALUES (:field1, :field2)

并准备声明:

$stmt = $dbh->prepare($sql);

<强>3。绑定(bind)参数

然后您可以将参数动态绑定(bind)到占位符:

foreach ($data as $placeholder => $value) {
    $stmt->bindValue(":$placeholder", $value);
 }

并执行:

$stmt->execute();

更高级一点...

关于php - 使用 PDO 向表中插入大量变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13333006/

相关文章:

php - 有些东西让我的页面多次执行 Ajax 调用... [读取 : I've never been more frustrated with something so 'simple' in my life]

MySQL:一列的总和基于另一列的值

MySQL CSV 文件导入日期时间

php - 当来自 $_GET 的值时,PDO bindValue 不起作用

php - php中的这个 "iif"是什么意思?

php - Laravel 密码验证规则

php - 如何对特定文件夹设置 777 权限?

mysql - 从 SQL 查询中排除一些结果

PHP echo 不显示在 HTML <h3> 标签内

php - 如何使用 __autoload 从多个目录加载类?