首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PDO数据库访问,其中title = $title

PDO数据库访问,其中title = $title
EN

Stack Overflow用户
提问于 2011-03-07 17:57:52
回答 5查看 1.1K关注 0票数 0

我正在努力学习如何使用PDO而不是MySQLi来访问数据库,而且我在从数据库中选择数据时遇到了困难。我想用:

代码语言:javascript
复制
$STH = $DBH->query('SELECT * FROM ratings WHERE title=$title ORDER BY date ASC');
$STH->setFetchMode(PDO::FETCH_ASSOC);

while($row = $STH->fetch()) {
    echo $row['title']; 
}

但我发现了一个错误:

致命错误:在第6行的/home/owencont/public_html/owenstest.com/ratemystudents/index.php中调用非对象上的成员函数setFetchMode()

如果我拿出WHERE语句就行了。如果行的值与变量匹配,如何选择行?

谢谢,

欧文

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2011-03-07 18:04:15

这很可能是SQL语法错误,因为您忘记引用$title了。它在查询中以空字结束(甚至没有作为字符串进行内插),从而导致错误。并且您的PDO连接没有配置为报告错误。对->quote()之前的参数使用->query():

代码语言:javascript
复制
$title = $DBH->quote($title);
$STH = $DBH->query("SELECT * FROM ratings WHERE title=$title ");

或者更好的是,使用参数化SQL:

代码语言:javascript
复制
$STH = $DBH->prepare("SELECT * FROM ratings WHERE title=? ");
$STH->execute(array($title));
票数 2
EN

Stack Overflow用户

发布于 2011-03-07 18:02:57

看看PDO::准备PDOStatement::execute。向查询添加用户内容的最安全方法是准备一个基本语句并将参数绑定到该语句。示例(注意SQL语句中的问号):

代码语言:javascript
复制
$STH = $DBH->query('SELECT * FROM ratings WHERE title=? ORDER BY date ASC');
$STH->execute( array( $title ) );

while( $row = $STH->fetch( PDO::FETCH_ASSOC ) );
票数 1
EN

Stack Overflow用户

发布于 2011-03-07 18:03:32

  1. 让PDO抛出错误,这样您就可以看到到底出了什么问题。请参阅如何从PDO中抽取错误信息?
  2. 您可能忽略了$title周围的引号,但是这个场景实际上需要使用准备好的陈述
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5223304

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档