简体   繁体   English

Django ORM表关系

[英]Django ORM Table Relationships

I have models defined like so: 我有这样定义的模型:

class Games(models.Model):
    title = models.CharField(max_length=50)
    owned = models.BooleanField(default=False)
    created = models.DateTimeField(auto_now_add=True)


class Votes(models.Model):
    game = models.ForeignKey(Games)
    created = models.DateTimeField(auto_now_add=True)

And i'm doing the following in my view: 我认为以下几点:

wanted = Games.objects.filter(owned=0)
for game in wanted:
    game.vote = Votes.objects.all().filter(game_id=game.id).count()
wanted = sorted(wanted, key=attrgetter('vote'), reverse=True)

It works fine but is there a more Django way of doing this? 它工作正常,但是还有更多的Django方法吗?

from django.db.models import Count
Games.objects.filter(owned=0).annotate(vote=Count('votes')).order_by('-vote')

see Django aggregation for more information 有关更多信息,请参见Django聚合

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM