1

我正在开发一个 Extjs 4 应用程序,我使用从 GUI 发送的参数(文本框、组合框值等)执行查询。该查询是使用 SQLAlchemy 构建的。我在本地主机上使用 MySQL 数据库。

我执行的查询旨在返回大数据。我的问题是当我直接在 HeidiSQL 上执行查询时,它会在 0.6 秒内执行,但是使用 Extjs(在 chrome 上)它会产生超时并且不显示任何结果。

这是查询。当我执行它时,它应该返回 300.000 行。

SELECT  /*ALL OF THE COLUMNS OF MY TWO TABLES, GENERATED DYNAMICALLY WITH SQLAlchemy*/
FROM bl, `CR`
WHERE `CR`.`Category` IN ('Failure') AND bl.severity_logged IN ('4_minor') AND bl.product_logged = 'x' AND bl.`productRelease_logged` IN ('0.1', '6.2', '6.4', '6.7');

可能是什么问题呢?是浏览器缓存问题吗?

编辑:这是我的带有 SQLAlchemy 的 Python 脚本。

engine = create_engine(
             "mysql://:@localhost/test",
             isolation_level="READ UNCOMMITTED"
        )
meta = MetaData(bind=engine)
meta.reflect(bind=engine)
cr =  meta.tables['cr']
bl = meta.tables['bl']

session = create_session(bind=engine)
...#I create filters based on the GUI values
test_query = session.query(metric_table_object,cr).filter(all_filters) #I then create the query
result_dict = [u.__dict__ for u in test_query.all()] #I store the query result into a dict
print result_dict
4

1 回答 1

0

正如zzzeek 评论,加载 300,000 个结果对象可能会使用太多内存。也许您可以使用像Windowed Range Query这样的策略来处理数据块?SqlAlchemy 邮件列表上的这篇文章也有一些有用的细节关于将你的结果分割成块。

于 2013-12-24T01:14:33.917 回答