2011-08-25 58 views
0

我有以下代码:使用fetchall陷入

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

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

我知道这是没有足够的信息,但我不明白为什么代码执行只有当我评论的使用fetchall线。当该行执行时,我什么都没有,只是空白的浏览器,没有任何错误或任何东西。在萤火虫的回应是空白的...它可能是什么?

+0

你期望在浏览器中看到什么?检查是否在php.ini中打开了错误报告。另外,你在处理MySQL错误吗? – rubayeet

回答

6

您在做笛卡尔产品tabletable2。这可能是大量的数据。

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

你要么需要一个JOIN:

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

或联合

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

如果笛卡尔乘积就是你要真的是,尝试添加一个极限,看看是否可行。然后稍后增加或删除限制

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

根据您的表包含(您确实没有提供足够的信息)。

+0

这是一个很多的数据:p为什么这会成为一个问题? – luqita

+1

@luqita:因为PHP在存储最小/最简单的数据方面存在相当大的内存开销。你基本上试图将你的两个表SQUARED的全部内容加载到内存中。 –

+0

尝试先获取较小的数据。如果这样做,你正在达到一定的限制。也许你的PHP脚本有一个最大执行时间设置,或者你的内存不足,或者你的请求超时... – Konerak

0

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

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