3

我正在构建一个带有一些非常简单查询的 Django 应用程序。当我在本地运行它时,性能很差:DebugToolbar 报告4119.00 ms (6 queries)这显然很糟糕。运行时间最长的查询是这个:

姜戈views.py代码:

reviews = list(Review.objects.select_related('band', 'record', 'label').order_by('-date_posted')[:12])

输出的 SQL:

SELECT * FROM `reviews` 
INNER JOIN `bands` ON (`reviews`.`band_id` = `bands`.`id`) 
INNER JOIN `records` ON (`reviews`.`record_id` = `records`.`id`) 
INNER JOIN `label` ON (`reviews`.`label_id` = `label`.`id`) 
ORDER BY `reviews`.`date_posted` DESC 
LIMIT 12

现在显然那里有一些连接,但我的表已正确索引。当我在 phpMyAdmin 中运行该查询时,我得到Query took 0.0241 sec了,但在 DebugToolbar 中我看到了1838.00 ms。其他 5 个查询同样缓慢,但直接查询时运行正常。

我在 Windows 上运行 Django 并使用 MySQL(WAMP 服务器)。谁能想到为什么 Django 自己的查询会这么慢?

4

2 回答 2

2
  1. 确保您使用相同的数据库进行比较。如果一个数据量小,而另一个数据量大,时间就会改变。指出这听起来很愚蠢,但已经犯了更简单的错误。

  2. 在 Django 中,设置DEBUG=False,以便 Django 不会存储和跟踪查询,这可能会增加开销。我不希望它会像您看到的那样增加,但是您需要使环境逼真。

于 2012-06-09T12:59:15.797 回答
0

这个答案真的很晚,但如果其他人正在寻找解决方案,它可能会有所帮助。我在 Windows 上遇到了同样的问题,但是当我禁用缓存时它得到了解决。

于 2020-11-06T12:36:20.200 回答