2

我是 Django 开发新手,刚刚开始编写应用程序。我在 models.py 中定义了两个类:

from django.db import models
from django.utils import timezone
from django.contrib.auth.models import User

class NEO(models.Model):
    name        = models.CharField(max_length=100, default=' ')
    sighter     = models.ForeignKey(User, blank=True, null=True)
    date_sighted    = models.DateTimeField(default=timezone.now())
    ratings     = models.IntegerField(default=0)
    #coords     = models.ForeignKey('Coords', default='')

    def __unicode__(self):
        return self.name

class Coords(models.Model):
    ra      = models.FloatField('Right Ascension', default=0)
    dec     = models.FloatField('Declination', default=0)
    neo     = models.ForeignKey(NEO, related_name='neo_coords', null=True)

    def __unicode__(self):
        return str(self.ra) + ' ' + str(self.dec)

每个Coords对象链接到一个对象NEO,反之亦然。取消注释该Neo.Coords行,然后调用n.Coords返回一个None. 给定一个NEO对象,如何获取对应的Coords对象?

4

2 回答 2

4

这里的 ForeignKey 是 ManyToOne 关系(如文档中所建议的那样),因此在您的情况下,Coords可以将多个对象绑定到单个NEO对象。如果您想要 OneToOne 关系,您可能想要使用models.OneToOneField此处的文档)。

在外键查找的情况下,您可以使用。

NEO.coords_set.get(**lookup_arguments_here)
# Here NEO.coords_set is the list of coords objects bound to this particular NEO object.

如果OneToOne你可以简单地使用

NEO.coords
于 2013-03-20T11:16:06.227 回答
1

让两个表用双外键相互引用是没有意义的,因为你会遇到鸡或蛋的问题。您需要决定是否可以存在一对多关系或一对一关系。

一个可以NEO有多个Coords吗?一个可以Coord有多个NEOs吗?如果答案是肯定的,那么您需要一个ForeignKey. ForeignKey应该在关系的许多方面one-to-many。如果答案是否定的,并且只能是一对一的链接,那么您需要一个OneToOneField.

要访问关系的反面,很简单:

# multiple coords per neo

class NEO(models.Model):
    name = ...

class Coords(models.Model):
    name = ...
    neo = models.ForeignKey(NEO)

c = Coords.objects.get(id=1)
c.neo # shows the neo

n = NEO.objects.get(id=1)
coords = n.coords_set.all() # multiple coords per neo

相反,如果您有一对一的关系:

class NEO(models.Model):
    name = ...

class Coords(models.Model):
    name = ...
    neo = models.OneToOneField(NEO)

c = Coords.objects.get(id=1)
c.neo # shows the neo

n = NEO.objects.get(id=1)
coords = n.coords # only one possible coord per neo

https://docs.djangoproject.com/en/dev/topics/db/queries/#lookups-that-span-relationships

于 2013-03-20T11:54:43.087 回答