fetchAll卡住了

时间:2011-08-25 19:13:57

标签: php mysql pdo fetchall

我有以下代码:

    $sql = "SELECT table.field, table2.field2 FROM
                table, table2";
    $stmt = $this->db->prepare($sql);
    $stmt->execute();

    $x = $stmt->fetchAll(PDO::FETCH_ASSOC);

我知道这些信息不够,但我不明白为什么代码只有在我评论fetchAll行时才会执行。当该行执行时,我没有得到任何东西,只是空白浏览器,没有错误或任何东西。在萤火虫中,响应是空白的......它可能是什么?

2 个答案:

答案 0 :(得分:6)

您正在使用tabletable2笛卡尔积“。这可能是一大笔数据。

对于表格中的每一行,您将获得table2中的所有行。因此,如果table有100行,而table2有500行,您的查询将尝试获取50.000行。

你要么想要加入:

SELECT table.field, table2.field2 
FROM table 
JOIN table2 
ON table.field3 = table2.field3

或UNION

SELECT table.field AS FIELDNAME FROM table
UNION ALL
SELECT table2.field2 AS FIELDNAME FROM table2

如果笛卡尔积非常符合您的要求,请尝试添加LIMIT,看看是否有效。然后增加或删除限制

SELECT table.field, table2.field2 
FROM table, table2 LIMIT 10

取决于您的表包含的内容(您确实没有提供足够的信息)。

答案 1 :(得分:0)

要捕获错误,您应该启用error_reporting和display_errors。 我认为这种行为的原因是你得到“允许内存限制”。也许你从db获得太多行。

尝试添加ini_set('memory_limit','256M')并检查工作。