首页 > 解决方案 > 如何从视图中的 QuerySet 中选择 OnetoOne 字段?

问题描述

查看所有用户(未启用 search_hidden)视图

@login_required
def users(request):
    """List all users page"""
    t_users = User.objects.all()
    users = t_users.usersettings.filter(search_hidden=False).select_related('user')

    context = {'users': users}
    return render(request, 'users/users.html', context)

用户设置模型

from django.db import models
from django.contrib.auth.models import User
from django.db.models.signals import post_save
from django.dispatch import receiver

class UserSettings(models.Model):
    """Stores the user's settings."""

    user = models.OneToOneField(User, related_name='usersettings', on_delete=models.CASCADE)
    public_profile = models.BooleanField(default=True)
    search_hidden = models.BooleanField(default=False)

    class Meta:
        verbose_name_plural = 'usersettings'

    def __str__(self):
        return f"{self.user}'s settings"

@receiver(post_save, sender=User)
def create_user_usersettings(sender, instance, created, **kwargs):
    if created:
        UserSettings.objects.create(user=instance)

@receiver(post_save, sender=User)
def save_user_usersettings(sender, instance, **kwargs):
    instance.usersettings.save()

创建帐户时,所有用户都有一个与之关联的 UserSettings 模型。在我看来,我想选择所有禁用了 search_hidden 的用户,但是我尝试过的方法不起作用。'QuerySet' object has no attribute 'usersettings'每当请求页面时都会显示错误。我可能需要选择每个用户并检索设置,但我不知道如何以有效的方式做到这一点。

标签: pythondjangodjango-queryset

解决方案


iliya评论说,过滤使用t_users.objects.filter(search_hidden=False)将返回在其设置对象中search_hidden不为真的用户。


推荐阅读