sql - 使用 select_related() 的 Django 过滤器

标签 sql django django-models

我有以下完美运行的查询:

    campaignFixtures = UserSelection.objects.select_related().filter(user=currentUserID,campaignno=currentCampaignNo).order_by('fixtureid__fixturedate')[:1]

但是,我需要从另一个表中过滤一个字段,如下所示:

    campaignFixtures = UserSelection.objects.select_related().filter(user=currentUserID,campaignno=currentCampaignNo,straightredfixture__fixturematchday=18).order_by('fixtureid__fixturedate')[:1]

但是,我收到以下错误:

Cannot resolve keyword 'straightredfixture' into field. Choices are: campaignno, fixtureid, fixtureid_id, teamselection1or2, teamselectionid, teamselectionid_id, user, user_id, userselectionid

模型如下:

class StraightredFixture(models.Model):
    fixtureid = models.IntegerField(primary_key=True)
    home_team = models.ForeignKey('straightred.StraightredTeam', db_column='hometeamid', related_name='home_fixtures')
    away_team = models.ForeignKey('straightred.StraightredTeam', db_column='awayteamid', related_name='away_fixtures')
    fixturedate = models.DateTimeField(null=True)
    fixturestatus = models.CharField(max_length=24,null=True)
    fixturematchday = models.ForeignKey('straightred.StraightredFixtureMatchday', db_column='fixturematchday')
    spectators = models.IntegerField(null=True)
    hometeamscore = models.IntegerField(null=True)
    awayteamscore = models.IntegerField(null=True)
    homegoaldetails = models.TextField(null=True)
    awaygoaldetails = models.TextField(null=True)
    hometeamyellowcarddetails = models.TextField(null=True)
    awayteamyellowcarddetails = models.TextField(null=True)
    hometeamredcarddetails = models.TextField(null=True)
    awayteamredcarddetails = models.TextField(null=True)
    soccerseason = models.ForeignKey('straightred.StraightredSeason', db_column='soccerseasonid', related_name='fixture_season')


    def __unicode__(self):
        return self.fixtureid

    class Meta:
        managed = True
        db_table = 'straightred_fixture'

class UserSelection(models.Model):
    userselectionid = models.AutoField(primary_key=True)
    campaignno = models.CharField(max_length=36,unique=False)
    user = models.ForeignKey(User, related_name='selectionUser')
    teamselection1or2 = models.PositiveSmallIntegerField()
    teamselectionid = models.ForeignKey('straightred.StraightredTeam', db_column='teamselectionid', related_name='teamID')
    fixtureid = models.ForeignKey('straightred.StraightredFixture', db_column='fixtureid')


    class Meta:
        managed = True
        db_table = 'straightred_userselection'

Alan,我们将不胜感激。

最佳答案

我认为问题与selected_related 无关。您只是试图使用错误的查找值进行过滤。如何使用 fixtureid__fixturematchday 进行过滤:

UserSelection.objects.select_related().filter(user=currentUserID, campaignno=currentCampaignNo, fixtureid__fixturematchday=18).order_by('fixtureid__fixturedate')[:1]

既然你只想得到一个对象,为什么不直接使用.first()呢?获取对象而不是包含一项的查询集:

campaignFixture = UserSelection.objects.select_related("fixtureid").filter(...).order_by(...).first()

关于sql - 使用 select_related() 的 Django 过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41252033/

相关文章:

sql - 在 SQL Server 2008 中区分两个表模式的最简单方法?

mysql - 其中 like 和 order by 在不同的表/列上

mysql - 错误 : syntax error at or near ";" Position: 102

java - Hibernate,无法执行查询,SQL 错误 : 17059, SQLState:99999

django - 如何将详细信息对象传递给 tastypie 中的自定义授权?

python - 模型表单在 django 中的外键上崩溃

django - 手动创建 Django QuerySet 或者手动将对象添加到 QuerySet

django - 根据同一表单django字段中的所选项目过滤表单字段中的选择

python - Django 多对多关系不返回集合对象

django - 如何获取查询集中的选项值?