Django 所有查询的select_related
例子
外键模型
我们将使用以下模型:
fromdjango.dbimport models class Book(models.Model): name= models.CharField(max_length=50) author = models.ForeignKey(Author) class Author(models.Model): name = models.CharField(max_length=50)
假设我们经常(总是)访问book.author.name
视野中
每次我们可以使用以下内容
books = Book.objects.select_related('author').all()但这不是DRY。
客户经理
class BookManager(models.Manager):
def get_queryset(self):
qs = super().get_queryset()
return qs.select_related('author')
class Book(models.Model):
...
objects = BookManager()注意:super必须更改对python2.x的调用
现在我们需要在视图中使用的是
books = Book.objects.all()
并且不会在模板/视图中进行其他查询。
热门推荐
10 诗词送行祝福语大全简短
11 新房开工吉日祝福语简短
12 50多岁生日简短祝福语
13 安徽疫情祝福语简短英语
14 农民朋友发财祝福语简短
15 对生活祝福语简短精辟
16 搬家词简短祝福语朋友
17 女神结婚快乐祝福语简短
18 文学短句祝福语大全简短