1

我有两个应用程序,“帐户”和“myapp”。我试图在视图中仅显示与 request.user 属于同一组织的那些教师对象。

帐户/models.py
from django.contrib.auth.models import User

class Organisation(models.Model):
    name = models.CharField(max_length=100, unique=True)
    is_active = models.BooleanField(default=True)

class UserProfile(models.Model):
    user = models.OneToOneField(User, unique=True)
    organisation = models.ForeignKey(Organisation, editable=False)
    is_organisationadmin = models.BooleanField(default=False)

User.profile = property(lambda u: UserProfile.objects.get_or_create(user=u)[0])

请注意此博客文章中的最后一行,它可以通过类似的方式访问用户个人资料信息user.profile.organisation

myapp/models.py
from django.contrib.auth.models import User

class Teacher(models.Model):
    user = models.OneToOneField(User, related_name='teacher')
我的应用程序/views.py
from myproject.account.models import Organisation, UserProfile
from myproject.myapp.models import Teacher
from django.contrib.auth.models import User

def homepage(request):
    if request.user.is_authenticated():
        teachers = Teacher.objects.filter(user.profile.organisation == request.user.profile.organisation, user__is_active = True)

我收到“/homepage/ 处的 NameError,未定义全局名称 'user'”。我认为这是因为我没有正确访问每个 Teacher 对象的 teacher.user 属性,但我可能是错的。

我尝试了各种反向遍历关系的组合:

user.is_active
user__is_active
user.profile.organisation
user.profile__organisation

但是上面的很多都给了我“/homepage/关键字的SyntaxError不能是一个表达式”,所以我认为目前的化身大致是正确的。

奇怪的是,过滤器的右侧似乎工作正常(= request.user.profile.organisation部分)

4

1 回答 1

5

有关跨越关系的查询查找的文档非常有用。要实现的是它是一个标准函数,所以左侧必须始终是单个关键字,而不是表达式。要启用此功能,请使用双下划线语法:

Teacher.objects.filter(user__profile__organisation=request.user.profile.organisation, user__is_active = True)

还要注意它是一个单一的=- 再次,它是一个函数调用,而不是一个表达式。

于 2012-03-05T20:07:57.043 回答