dongzhuang6247 2019-08-16 19:20
浏览 196
已采纳

PHP致命错误:未捕获错误:调用布尔值[duplicate]上的成员函数setFetchMode()

This question already has an answer here:

I understand that this error occurs when you try to call a method on something that is not an object. In this case, the variable that should hold an object is actually a boolean.

I just don't know how to fix it.

If you look at MySQL::query(), the function returns either false (on error) or an object of the type mysql_result. A bad SQL query will make the query fail and the function to return false.

Because the error occurs when I try to call setFetchMode, it probably means my PDO query failed, but I honestly have no idea.

<?php

$host = 'localhost';
$dbname = 'DBNAME';
$username = 'USERNAME';
$password = 'PASSWORD';

try {

   $pdo = new PDO("mysql:host=$host;dbname=$dbname", $username, $password);

   $sql = 'SELECT id, topic, category, type, doi, author, year
   FROM literature
   ORDER BY id';

   $q = $pdo->query($sql);

   $q->setFetchMode(PDO::FETCH_ASSOC);

} catch (PDOException $e) {

   die("Could not connect to the database $dbname :" . $e->getMessage());

}

?>

It returns the error: "PHP Fatal error: Uncaught Error: Call to a member function setFetchMode() on boolean in /root/somewhere/somefile/anotherfile/FILENAME.php:12" because $q is false. I just don't know how to have it return the object.

The weird part is that it works perfectly fine on my stand-alone server.

</div>
  • 写回答

2条回答 默认 最新

  • duanban4769 2019-08-16 19:59
    关注

    if your $q is false its mean you have error in sql query or a connection, you can use this connection to see more info about your error:

    $pdo = new PDO("mysql:host=$host;dbname=$dbname", $username, $password, [PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]);
    

    then it will throw exception before you try to access (bool)->{someMethod}

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 AT89C51控制8位八段数码管显示时钟。
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题