PDO获取模式 - 查询之前/之后

时间:2013-01-17 21:24:43

标签: php pdo

我想知道为什么你可以在执行查询之前和之后设置获取模式,结果仍然使用给定的获取模式......?

这意味着PDO从数据库服务器检索查询结果为numeric和assoc?嗯...

是否只能检索一个..?数字结果还是关联结果?

这两个示例返回完全相同的结果..如果我将setFetchMode两个数字和关联结果都打印出来

执行前

$sth = $dbh->prepare("SELECT REFERENCED_TABLE_NAME table_name, REFERENCED_COLUMN_NAME column_name\n"
    ."FROM KEY_COLUMN_USAGE\n"
    ."WHERE REFERENCED_TABLE_NAME IS NOT NULL && REFERENCED_COLUMN_NAME IS NOT NULL\n"
    ."GROUP BY REFERENCED_TABLE_NAME, REFERENCED_COLUMN_NAME");
$sth->setFetchMode(PDO::FETCH_ASSOC);
$sth->execute();

echo '<pre>';
foreach($sth as $row){
    print_r($row);
}
echo '</pre>';

执行后

$sth = $dbh->prepare("SELECT REFERENCED_TABLE_NAME table_name, REFERENCED_COLUMN_NAME column_name\n"
    ."FROM KEY_COLUMN_USAGE\n"
    ."WHERE REFERENCED_TABLE_NAME IS NOT NULL && REFERENCED_COLUMN_NAME IS NOT NULL\n"
    ."GROUP BY REFERENCED_TABLE_NAME, REFERENCED_COLUMN_NAME");
$sth->execute();
$sth->setFetchMode(PDO::FETCH_ASSOC);

echo '<pre>';
foreach($sth as $row){
    print_r($row);
}
echo '</pre>';

1 个答案:

答案 0 :(得分:5)

您的示例使用简化:执行后,但在使用记录之前,您还需要获取它们。这些是PDOStatement class中的fetch和fetchAll方法。

但是当使用foreach构造时,你正在使用PDOStatement的Traversable接口,它在foreach循环的开始处调用fetchAll方法而不是你。

因此,在这两个示例中,在设置获取模式后都会调用fetchAll。

编辑:

  

这意味着PDO将查询结果检索为数字和   来自db服务器的assoc?嗯...

PDO不会以一种或两种方式从数据库中获取记录,它将始终以相同的方式进行 - 不同之处在于它将如何向您呈现结果。如果指定了获取模式,PDO将为您构建所请求的结构。如果使用默认值,或指定FETCH_BOTH,它将构建两个不同的表示形式,但来自相同的结果集。此参数不会对发送到SQL Server的命令产生影响。