3
我有以下Django模型:如何标注在多个Django模型
class Book(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=200)
class Meta:
db_table = "books"
class BookCategory(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=50)
class Meta:
db_table = "bookcategories"
class BookCategoryMembership(models.Model):
id = models.AutoField(primary_key=True)
category = models.ForeignKey(BookCategory)
book = models.ForeignKey(Book)
class Meta:
db_table = "bookcategories_books"
class UserBook(models.Model):
id = models.AutoField(primary_key=True)
user = models.ForeignKey(settings.AUTH_USER_MODEL, null=True)
book = models.ForeignKey(Book)
class Meta:
db_table = "user_book"
的UserBook
模型来表示,如果用户拥有一本书。
现在,我想返回所有图书类别的列表,按照大多数图书的数量排序(即最热门的类别应该首先出现)。
我试着用Django的ORM注解,但我没有得到它的工作。
这是行不通的子查询:
BookCategoryMembership.objects.annotate(num_books=Count("book__userbook")).
values('category_id').annotate(Sum('num_books'))
(导致错误信息
FieldError: Cannot compute Sum('num_books'): 'num_books is an aggregate"
我知道,从这个子查询中,ORDER_BY子句人仍下落不明,但我相信我必须先让子查询先行工作
你知道用哪个查询我可以在django中解决这个问题吗?我想避免将它分解为多个查询或在Django中进行任何计算。
在一个QuerySet中与聚合中的重用列有相同的问题。 – 2017-04-14 10:43:41