我想问一下如何通过django中基于类的视图列出已记录的当前用户的所有对象。
我在项目中有两个应用程序。一个叫做用户,另一个叫羽毛球。
users / models.py
from django.db import models
from django.contrib.auth.models import User
class Profile(models.Model):
user = models.OneToOneField(User, null=True, on_delete=models.CASCADE)
name = models.CharField(max_length=200, null=True)
羽毛球/models.py
from django.db import models
from users import models as users_models
class Player(models.Model):
name = models.OneToOneField(users_models.Profile ,null=True, on_delete=models.CASCADE)
matches_played = models.IntegerField(default=0, blank=True, null=True)
class Match(models.Model):
player_home = models.OneToOneField(Player, null=True, on_delete= models.SET_NULL, related_name='player_home')
player_away = models.OneToOneField(Player, null=True, on_delete= models.SET_NULL, related_name='player_away')
如何通过queryset访问登录用户的所有匹配项?感谢您的帮助!
您可以列出Matche
的,其request.user
具有as作为Player
对象player_home
和/或player_away
与匹配的对象:
from django.db.models import Q
Match.objects.filter(
Q(player_home__name__user=request.user) |
Q(player_away__name__user=request.user)
)
注意:外键指向一个对象,而不是该对象的字符串表示形式。因此
name
,并不是真正引用Profile
对象的好名字。您可能需要考虑将其重命名为profile
。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句