微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PDO在执行语句期间受行影响

如何解决PDO在执行语句期间受行影响

尝试$q->rowCount()。准备好的语句将通过该方法返回受影响的行数。

解决方法

我发现有很多方法可以将exec语句用于PDO,但是我不确定它是否对我有帮助。我的理解是我必须对准备好的语句使用execute()函数。我正在使用来自用户输入的数据更新一行,因此我想使用一个准备好的语句而不是query()调用。

我的代码如下:

$dbh = buildDBConnector(); 
$sql = "UPDATE tb_users 
    SET authState=1
    WHERE id = ? AND authPass = ?";
$q = $dbh->prepare($sql);
$f = $q->execute(array($id,$authPass));
if($f){
    echo '<br />Success<br />';
}else{
    echo '<br />Failure<br />';
}

问题是查询本身没有错误并且可以正常执行,因此在$
f中存储没有错误。但是,我需要知道它是否确实找到要更新的行,然后成功更新了它。换句话说,我需要受影响的行。当进行谷歌搜索时,它会不断出现在exec语句中,但是据我了解,exec不是用于准备好的语句吗?有什么建议么?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。