我有以下代码:
$sql = "SELECT table.field, table2.field2 FROM
table, table2";
$stmt = $this->db->prepare($sql);
$stmt->execute();
$x = $stmt->fetchAll(PDO::FETCH_ASSOC);
我知道这些信息不够,但我不明白为什么代码只有在我评论fetchAll行时才会执行。当该行执行时,我没有得到任何东西,只是空白浏览器,没有错误或任何东西。在萤火虫中,响应是空白的......它可能是什么?
答案 0 :(得分:6)
您正在使用table
和table2
的笛卡尔积“。这可能是一大笔数据。
对于表格中的每一行,您将获得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')并检查工作。