• 相关对象
    • 访问外键(Foreign Key)值
    • 访问多对多值(Many-to-Many Values)

    相关对象

    先让我们回忆一下在第五章里的关于书本(book)的数据模型:

    1. from django.db import models
    2. class Publisher(models.Model):
    3. name = models.CharField(max_length=30)
    4. address = models.CharField(max_length=50)
    5. city = models.CharField(max_length=60)
    6. state_province = models.CharField(max_length=30)
    7. country = models.CharField(max_length=50)
    8. website = models.URLField()
    9. def __unicode__(self):
    10. return self.name
    11. class Author(models.Model):
    12. first_name = models.CharField(max_length=30)
    13. last_name = models.CharField(max_length=40)
    14. email = models.EmailField()
    15. def __unicode__(self):
    16. return u'%s %s' % (self.first_name, self.last_name)
    17. class Book(models.Model):
    18. title = models.CharField(max_length=100)
    19. authors = models.ManyToManyField(Author)
    20. publisher = models.ForeignKey(Publisher)
    21. publication_date = models.DateField()
    22. def __unicode__(self):
    23. return self.title

    如我们在第5章的讲解,获取数据库对象的特定字段的值只需直接使用属性。 例如,要确定ID为50的书本的标题,我们这样做:

    1. >>> from mysite.books.models import Book
    2. >>> b = Book.objects.get(id=50)
    3. >>> b.title
    4. u'The Django Book'

    但是,在之前有一件我们没提及到的是表现为ForeignKeyManyToManyField的关联对象字段,它们的作用稍有不同。

    访问外键(Foreign Key)值

    当你获取一个ForeignKey 字段时,你会得到相关的数据模型对象。 例如:

    1. >>> b = Book.objects.get(id=50)
    2. >>> b.publisher
    3. <Publisher: Apress Publishing>
    4. >>> b.publisher.website
    5. u'http://www.apress.com/'

    对于用ForeignKey 来定义的关系来说,在关系的另一端也能反向的追溯回来,只不过由于不对称性的关系而稍有不同。 通过一个publisher 对象,直接获取 books ,用 publisher.book_set.all() ,如下:

    1. >>> p = Publisher.objects.get(name='Apress Publishing')
    2. >>> p.book_set.all()
    3. [<Book: The Django Book>, <Book: Dive Into Python>, ...]

    实际上,book_set 只是一个 QuerySet(参考第5章的介绍),所以它可以像QuerySet一样,能实现数据过滤和分切,例如:

    1. >>> p = Publisher.objects.get(name='Apress Publishing')
    2. >>> p.book_set.filter(name__icontains='django')
    3. [<Book: The Django Book>, <Book: Pro Django>]

    属性名称book_set是由模型名称的小写(如book)加_set组成的。

    访问多对多值(Many-to-Many Values)

    多对多和外键工作方式相同,只不过我们处理的是QuerySet而不是模型实例。 例如,这里是如何查看书籍的作者:

    1. >>> b = Book.objects.get(id=50)
    2. >>> b.authors.all()
    3. [<Author: Adrian Holovaty>, <Author: Jacob Kaplan-Moss>]
    4. >>> b.authors.filter(first_name='Adrian')
    5. [<Author: Adrian Holovaty>]
    6. >>> b.authors.filter(first_name='Adam')
    7. []

    反向查询也可以。 要查看一个作者的所有书籍,使用author.book_set ,就如这样:

    1. >>> a = Author.objects.get(first_name='Adrian', last_name='Holovaty')
    2. >>> a.book_set.all()
    3. [<Book: The Django Book>, <Book: Adrian's Other Book>]

    这里,就像使用 ForeignKey字段一样,属性名book_set是在数据模型(model)名后追加_set