0

在我的 django 应用程序中,我有一个BlogEntry属于一个Category.ABlogEntry可能属于多个Categorys

class BlogEntry(models.Model):
    creationdate=models.DateField(default=date.today)    
    description=models.TextField()
    author=models.ForeignKey(User,null=True)
    categories=models.ManyToManyField(Category)

class Category(models.Model):
    name=models.CharField(unique=True,max_length=50)
    description=models.TextField(blank=True)

用户可以编辑 aBlogEntry并且这样做,可以删除Category它所在的 a。

假设以前blogEntry1属于java,scala。如果用户对其进行编辑以将其删除scala。现在该条目只有一个类别,即java

在我的 list_view 中,我使用缓存如下

from django.core.cache import cache
def list_entries_on_day(request,year,month,day):
    ...
    key = 'entries_day'+'-'+year+'-'+month+'-'+day
    if key not in cache:
        entries = BlogEntry.objects.filter(...args..)
        cache.set(key,entries)
    entries_on_day =cache.get(key)
    ...

假设我今天创建了 2 个条目并将它们放入缓存中。如果我编辑其中一个BlogEnty并删除一个类别,即;

blogEntry1  has categories :java,scala
blogEntry2 has categories :dotnet,vbasic

最初我查询今天的条目并将结果放入缓存中

缓存现在有[blogEntry1,blogEntry2]针对键'entries_day-2012-11-11'

现在我进行编辑blogEntry1,使其现在具有java类别

,我需要从缓存中删除存储的条目吗?(因为缓存BlogEntry在修改之前包含一个对象)

4

1 回答 1

1

您可以通过为 model.save 注册信号处理程序来使缓存无效

您还可以忍受这样一个事实,即用户将在缓存到期之前看到陈旧的内容(默认为 1 小时),确保他登录的用户不会看到缓存的内容,否则他会鸣喇叭编辑丢失。

嗯,我的回答有点含糊,但我只想说:不,您不必严格地在每次编辑时使缓存无效,这是性能和内容新鲜度之间的选择。

还有一点:缓存使用的首选习惯用法是:

entries_on_day = cache.get(key)
if entries_on_day  is None:
    entries_on_day  = BlogEntry.objects.filter(...args..)
    cache.set(key,entries_on_day)

您保存一个缓存查询

于 2012-11-11T10:49:50.327 回答