我有以下代码:
$sql = "SELECT table.field, table2.field2 FROM
table, table2";
$stmt = $this->db->prepare($sql);
$stmt->execute();
$x = $stmt->fetchAll(PDO::FETCH_ASSOC);我知道这是不够的信息,但我不明白为什么只有在注释fetchAll行的情况下代码才会执行。当这一行执行时,我没有得到任何东西,只有空白的浏览器,没有错误或任何东西。在firebug中,响应为空...那会是什么呢?
发布于 2011-08-26 03:15:57
您正在做的是table和table2的笛卡尔乘积。这可能是一个巨大的数据量。
对于表中的每一行,您将获得table2中的所有行。因此,如果table有100行,而table2有500行,那么您的查询将尝试获取50.000行。
你要么想要一个连接:
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这取决于您的表中包含的内容(您确实没有提供足够的信息)。
发布于 2011-08-26 03:18:09
为了捕获错误,您应该启用error_reporting和display_errors。我认为这种行为的原因是你得到了“允许的内存限制”。也许你从db得到的行太多了。
尝试添加ini_set('memory_limit','256M')并检查是否正常工作。
https://stackoverflow.com/questions/7195916
复制相似问题