首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >fetchAll卡住了

fetchAll卡住了
EN

Stack Overflow用户
提问于 2011-08-26 03:13:57
回答 2查看 394关注 0票数 0

我有以下代码:

代码语言:javascript
复制
    $sql = "SELECT table.field, table2.field2 FROM
                table, table2";
    $stmt = $this->db->prepare($sql);
    $stmt->execute();

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

我知道这是不够的信息,但我不明白为什么只有在注释fetchAll行的情况下代码才会执行。当这一行执行时,我没有得到任何东西,只有空白的浏览器,没有错误或任何东西。在firebug中,响应为空...那会是什么呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-08-26 03:15:57

您正在做的是tabletable2的笛卡尔乘积。这可能是一个巨大的数据量。

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

你要么想要一个连接:

代码语言:javascript
复制
SELECT table.field, table2.field2 
FROM table 
JOIN table2 
ON table.field3 = table2.field3

或者一个联盟

代码语言:javascript
复制
SELECT table.field AS FIELDNAME FROM table
UNION ALL
SELECT table2.field2 AS FIELDNAME FROM table2

如果笛卡尔产品真的是你想要的,试着添加一个限制,看看是否有效。然后再增加或删除限制

代码语言:javascript
复制
SELECT table.field, table2.field2 
FROM table, table2 LIMIT 10

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

票数 6
EN

Stack Overflow用户

发布于 2011-08-26 03:18:09

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

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7195916

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档