I have two models that are basically this:
Book(Model):
title = models.CharField(max_length = 250)
read_by = ManyToMa开发者_高级运维nyField(User)
...
User(Model):
firstName = models.CharField(max_length = 250)
lastName = models.CharField(max_length = 250)
...
Now, how do I create a list of all books with a "read" boolean for each book? In mysql I can use a ISNULL() with a OUTER JOIN. How can I do this in Django? Do I have to use raw mysql?
Clarification: I want to create the list for each user, so that each user can "tick off" each book they've read.
books = Book.objects.annotate(read=models.Count('read_by'))
Then if you want a list of read books only::
read_books = books.exclude(read=0)
Or you can just use the read
annoteted property of each instance which, being an integer, will obviously evaluate to the correct boolean value for unread books.
精彩评论