Mercurial > public > sg101
changeset 314:03b70aa5c872
The home page was taking 27 seconds to load; 99% of the time was being spent in the new_posts template tag query. Reworked it a bit to be much more sane.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sat, 29 Jan 2011 20:34:36 +0000 (2011-01-29) |
parents | 377dd359636f |
children | 36373d995611 |
files | gpp/forums/templatetags/forum_tags.py |
diffstat | 1 files changed, 19 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- a/gpp/forums/templatetags/forum_tags.py Thu Jan 27 03:00:16 2011 +0000 +++ b/gpp/forums/templatetags/forum_tags.py Sat Jan 29 20:34:36 2011 +0000 @@ -12,6 +12,7 @@ from forums.models import Forum from forums.models import Topic from forums.models import Post +from forums.models import Category from core.models import Statistic @@ -119,10 +120,26 @@ This tag displays the topics that have the newest posts. Only the "public" forums are displayed. """ - topics = Topic.objects.filter( - forum__category__groups__isnull=True).select_related( + public_forums = cache.get('public_forum_ids') + if public_forums is None: + public_forums = list(Forum.objects.filter( + category__groups__isnull=True).values_list('id', flat=True)) + cache.set('public_forum_ids', public_forums, 10 * 60) + + topics = Topic.objects.filter(forum__in=public_forums).select_related( 'user', 'last_post').order_by('-update_date')[:10] + # 1: + #public_cats = list(Category.objects.filter(groups__isnull=True).values_list('id', flat=True)) + #topics = Topic.objects.filter( + # forum__category__in=public_cats).select_related( + # 'user', 'last_post').order_by('-update_date')[:10] + + # 0: + #topics = Topic.objects.filter( + # forum__category__groups__isnull=True).select_related( + # 'user', 'last_post').order_by('-update_date')[:10] + return { 'topics': topics, 'user': context['user'],