在函数pdo中输入数组

时间:2014-09-27 19:39:00

标签: php mysql pdo

我正在尝试为PDO准备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();
}

但是我做错了,因为当我尝试运行函数Uncaught exception

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

传递的数组:

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')

1 个答案:

答案 0 :(得分:1)

语法错误 UPDATE语法总是如下:

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