1

好的,我正在使用 GLOBALS 在我的整个站点中设置一些设置

$tmp = $GLOBALS['_ODB']->query("SELECT * FROM `options`");
$GLOBALS['options'] = NameToTop($tmp->fetchAll(PDO::FETCH_ASSOC));

我有这个作为我的查询,然后我使用这个函数将返回的数据放入一个数组中

所以我可以通过使用来调用它$GLOBALS['settings']['setting1']

 function NameToTop($arr)
{
    $output = array();
    foreach ($arr as $val) {
        $output[$val['name']] = $val['value'];
    }
    return $output;
}

然后这里是设置表,我不明白为什么会出错;我真的需要一些帮助。

CREATE TABLE IF NOT EXISTS `options` (
  `ID` int(11) NOT NULL AUTO_INCREMENT,
  `name` text NOT NULL,
  `value` text NOT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=6 ;

--
-- Dumping data for table `options`
--

INSERT INTO `options` (`ID`, `name`, `value`) VALUES
(1, 'setting1', 'Name'),
(2, 'email', 'webmaster@gmail.com'),
(3, 'site_title', 'Title of Site'),

我越来越

在非对象上调用成员函数 fetchAll()

4

1 回答 1

0

您期望$tmp成为 PDOStatement 对象才能调用fetchAll()它,但事实并非如此,因此您会看到错误消息。

PDO::query()失败时返回 false,所以这很可能是正在发生的事情。

PDO 手册中的这条评论讨论了 的返回值query()

此函数对错误的处理由属性 PDO::ATTR_ERRMODE 控制。

使用以下方法使其抛出异常:

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

您需要阅读PDO 中的错误处理。大多数人确实倾向于走例外路线。

这将使您的示例如下所示:

try {
    $tmp = $GLOBALS['_ODB']->query("SELECT * FROM `options`");
    $GLOBALS['options'] = NameToTop($tmp->fetchAll(PDO::FETCH_ASSOC));
} catch (PDOException $e) {
    // handle the error in some way
    echo $e->getMessage();
}
于 2014-09-19T13:05:57.500 回答