У меня есть проблема с помощью объекта PDO PHP подготовить оператор обновления и обновляя запись. Я взял необработанный SQL-запрос и выполнил его в phpMyAdmin с параметрическими усилителями, замененными их значениями, которые передаются функции. Который обновляет запись, как предназначено. Однако, когда работал из сценария, он не обновляет. Это бросает нулевые ошибки, и это возвращает errorInfo () ответ 00000, чтобы к моему пониманию способ PDO сказать, что все хорошо. Я знаю работы объекта PDO, потому что это успешно вставляет и выбирает записи из базы данных, включая ту, которую я пытаюсь обновить. Я понимаю, что эта функция обновления ужасна, я просто изучаю PDO.
Очевидно, это кодируется в PHP5, с помощью PDO.
Функция класса:
public function update($tbl_name, $where = null, $what = null)
{
if(is_array($where))
{
$where_str = 'where ';
foreach($where as $key => $val)
{
$where_str .= "{$key} = ':{$key}' and ";
}
$where_str = substr($where_str,0,-5);
$what_str = 'set ';
foreach($what as $key => $val)
{
$what_str .= "`{$key}` = ':{$key}', ";
}
$what_str = substr($what_str,0,-2);
$query_str = "update {$tbl_name} {$what_str} {$where_str} LIMIT 1;";
$stmt = $this->dbh->prepare($query_str);
echo '<pre>'.print_r($stmt, true).'</pre>';
foreach($what as $key => $val)
{
if('date_time' === $key) continue;
$bind = $stmt->bindValue(":{$key}",$val);
echo ($bind ? 'true' : 'false')." :{$key}=",$val,'<br/>';
}
foreach($where as $key => $val)
{
if('date_time' === $key) continue;
$bind = $stmt->bindValue(":{$key}",$val);
echo ($bind ? 'true' : 'false')." :{$key} ",$val,'<br/>';
}
}else{
return false;
}
$this->dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$exec = $stmt->execute();
echo 'exec: '.($exec === true ? 'true:' : 'false:').':'.$exec.'<br/>';
echo '<pre>';
$stmt->debugDumpParams();
echo '</pre>';
return $stmt->errorInfo();
}
Названный от обновления/сценария входа в систему сессии:
$where = array(
'id' => $user['id'],
);
$what = array(
'twitter_key' => $oauth_token,
'twitter_secret' => $oauth_token_secret
);
$update = $db->update('users', $where, $what);
Вывод от echos и print_r в функции класса и вызывающей стороне:
// print_r($stmt = $this->dbh->prepare($query_str)) output:
PDOStatement Object
(
[queryString] => update users set `twitter_key` = ':twitter_key', `twitter_secret` = ':twitter_secret' where id = ':id' LIMIT 1;
)
// output from the bing params and execution returns
true :twitter_key=XXXXXXXXXXXXXXXXXXXXXXXXXXXX
true :twitter_secret=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
true :id 20
exec: true:1
// $stmt->debugDumpParams() output:
SQL: [111] update users set `twitter_key` = ':twitter_key', `twitter_secret` = ':twitter_secret' where id = ':id' LIMIT 1;
Params: 3
Key: Name: [12] :twitter_key
paramno=-1
name=[12] ":twitter_key"
is_param=1
param_type=2
Key: Name: [15] :twitter_secret
paramno=-1
name=[15] ":twitter_secret"
is_param=1
param_type=2
Key: Name: [3] :id
paramno=-1
name=[3] ":id"
is_param=1
param_type=2
// print_r($stmt->errorInfo()) output:
Array
(
[0] => 00000
)
Я не знаю много о PDO, Но мое чувство есть что-то не так с тем, как вы связываете параметры. Тем не менее, самый простой способ сказать точно, чтобы увидеть фактический запрос.
Согласно документам , вы должны увидеть сгенерированный запрос, так как он пошел к SQL в $ STMT-> QueryString
. Невозможно увидеть прямо сейчас, потому что вы обязательные параметры к утверждению после Вы выводятся $ STMT
.
Сделайте Print_r ()
после того, как вы связываете параметры (или, может быть, даже после выполнения запроса, я не знаю). Вы должны получить настоящую строку запроса и добраться до дна проблемы.
Исправлена функция класса, которая работает ... размещена здесь, если кто-то хочет, чтобы узнать из, использовать или что когда-либо.
public function update($tbl_name, $where = null, $what = null)
{
if(is_array($where) && is_array($what))
{
$where_str = 'where ';
foreach($where as $key => $val)
{
$where_str .= "{$key} = :{$key} and ";
}
$where_str = substr($where_str,0,-5);
$what_str = 'set ';
foreach($what as $key => $val)
{
$what_str .= "{$key} = :{$key}, ";
}
$what_str = substr($what_str,0,-2);
$query_str = "update {$tbl_name} {$what_str} {$where_str} LIMIT 1;";
$stmt = $this->dbh->prepare($query_str);
foreach($what as $key => $val)
{
if('date_time' === $key) continue;
$bind = $stmt->bindValue(":{$key}",$val);
}
foreach($where as $key => $val)
{
if('date_time' === $key) continue;
if('id' === $key)
{
$bind = $stmt->bindValue(":{$key}",$val, PDO::PARAM_INT);
}else{
$bind = $stmt->bindValue(":{$key}",$val);
}
}
}else{
return false;
}
$stmt->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$exec = $stmt->execute();
return $stmt->errorInfo();
}