1

testQuery() 是我用来从表 CATEGORIES 中获取所有行的方法

public function __construct()
 {
 self::$tdb = Database::getConnection();
 }



 #mock query to pull results from db
 public function testQuery()
  {
       $queryAA = "SELECT cat_name, cat_description, cat_id FROM CATEGORIES";
       $stmtAA = self::$tdb->prepare($queryAA);


       if ($stmtAA->execute() == true)
        {
             print("Execution was successful");
             return $stmtAA->fetch(PDO::FETCH_ASSOC);   
        }
       else
        {
            print("Warning statment did not successfully execute");
        }
     }

我通常使用 fetchAll() 但我被告知使用 fetch 因为它不会占用太多内存。但是我无法使用 fetch() 和下面的代码检索多行。

$test = new test();
$results = $test->testQuery();


foreach ($results as $row)
 {
 print_r($row);
 }

它只获取 1 行。那么如何检索和打印多行呢?之前提到过使用迭代,但我不确定是否实现它。任何帮助将不胜感激。谢谢!

4

2 回答 2

2

Fetch 确实一次从数据库中提取数据,但是您需要遍历行,直到获得所有数据。

您可能希望将其弹出到循环中以获取所有数据:

$stmtAA->fetch(PDO::FETCH_ASSOC);

这样的事情应该可以解决问题:

while($row=$this->prepared->fetch(PDO::FETCH_ASSOC))
{
    $this->ID=$row['id'];
    $something=$row['something'];
}

取决于您是填充变量还是在对象中包含代码。

于 2012-08-24T08:51:57.463 回答
1

您可以简单地返回语句对象。
或者,如果您想封装它(使其只能用于获取数据),请使用SPL 的 IteratorIterator

return new IteratorIterator($stmtAA);

那么你可以使用

foreach( testQuery() as $row) { ... }

在你的脚本中。

于 2012-08-24T08:56:42.643 回答