我有自己的Auth User模型,它继承自PermissionsMixin。虽然我正在访问django-admin页面以获取该模型的任何实例,但我获得了大量的数据库查询(因为我拥有很多权限)。问题出在这里,django / contrib / auth / models.py:
class Permission(models.Model):
[...]
def __str__(self):
return "%s | %s | %s" % (
six.text_type(self.content_type.app_label),
six.text_type(self.content_type),
six.text_type(self.name))
每次在管理页面上显示权限时,都会查询其content_type。
问题是:我可以确保对于涉及我的Auth用户模型的每个查询,特别是对于那些不是来自我的代码(例如django admin)的查询,将运行prefetch_related以获取权限及其content_types吗?
答案 0 :(得分:5)
如果您只需要django-admin,那么您可以使用official documentation中描述的技术创建自己的管理页面。
例如:
from django.contrib import admin
from django.contrib.auth.models import Permission
from foo.models import User
class UserAdmin(admin.ModelAdmin):
def formfield_for_manytomany(self, db_field, request=None, **kwargs):
if db_field.name == 'user_permissions':
kwargs['queryset'] = Permission.objects.all().select_related('content_type')
return super(UserAdmin, self).formfield_for_manytomany(db_field, request, **kwargs)
admin.site.register(User, UserAdmin)