Php 在函数pdo中输入数组

Php 在函数pdo中输入数组,php,mysql,pdo,Php,Mysql,Pdo,我试图为PDO prepare UPDATE语句创建一个统一的函数。但我做错了什么。非常感谢您的帮助 我正在向函数传递数组和电子邮件: function refreshUserData($items,$email) { global $pdo; $keys = array_keys($items); $keys = '('. implode(",", $keys) . ')'; $values = array_values($items); $valu

我试图为PDO prepare UPDATE语句创建一个统一的函数。但我做错了什么。非常感谢您的帮助

我正在向函数传递数组和电子邮件:

function refreshUserData($items,$email)
{
    global $pdo;

    $keys = array_keys($items);
    $keys = '('. implode(",", $keys) . ')';

    $values = array_values($items);
    $values = '(\''. implode("','", $values) . '\')';

    $query = $pdo->prepare("UPDATE users SET $keys VALUES $values WHERE email=?");
    $query->bindValue(1,$email);
    $query->execute();
}
但我做错了,因为当我尝试运行函数时
未捕获异常

这是我第一次尝试这样做,所以我不知道该怎么做

正在通过的数组:

Array ( [google_id] => 11111111111111 [emal] => email@gmail.com [first_name] => First [last_name] => Last [profile_url] => https://plus.google.com/+FirstLast )
在内爆之后:

(google_id,emal,first_name,last_name,profile_url)

('11111111111111','email@gmail.com','First','Last','https://plus.google.com/+FirstLast')

您的语法有错误 更新语法始终类似于:

UPDATE tablename
SET columname = 'value', othercolumn = 'othervalue'

您能给我们一个为$items变量传入的示例数组吗?非主题:请不要使用
global
!将您的功能抽象到类中并注入PDO句柄(或只是将其传递给函数),但从任何地方引用依赖项几乎都是不好的做法。哦,关于您的问题:您必须将值用单引号括起来:
$values=“(”)。内爆(“,”,“,$values)。“”)@Quasdunk在更改值的代码后:
$values='(\'''.intomode(“',”,$values)。'\'')仍然不工作有任何错误描述吗?或者你能捕捉到错误并回显信息吗?问题可能是拼写错误的
电子邮件
-字段。此外,如果不是复制粘贴,则内爆值字符串中的第一个和最后一个之间缺少引号。