Django笔记 数据库数据外键 多对多关系访问

来源:互联网 发布:今日非农数据结果 编辑:程序博客网 时间:2024/06/05 20:28
from django.db import models# Create your models here.class Publisher(models.Model):    name = models.CharField(max_length=30,blank=True,null=True)    address = models.CharField(max_length=50,blank=True,null=True)    city = models.CharField(max_length=60,blank=True,null=True)    state_province = models.CharField(max_length=50,blank=True,null=True)    webstie = models.URLField()    def __unicode__(self):        return self.nameclass Author(models.Model):    first_name = models.CharField(max_length=30,blank=False,null=False)    last_name = models.CharField(max_length=40,blank=False,null=False)    def __unicode__(self):        return u'%s %s' % (self.first_name,self.last_name)class Book(models.Model):    title = models.CharField(max_length=100,blank=False,null=False)    authors = models.ManyToManyField(Author)    publisher = models.ForeignKey(Publisher)    publication_data = models.DateField(blank=False,null=False)    def __unicode__(self):        return self.title

访问外键(Foreign Key)值
当你获取一个ForeignKey 字段时,你会得到相关的数据模型对象。 例如:

>>> b = Book.objects.get(id=50)>>> b.publisher<Publisher: Apress Publishing>>>> b.publisher.websiteu'http://www.apress.com/'

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

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

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

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

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

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

>>> b = Book.objects.get(id=50)>>> b.authors.all()[<Author: Adrian Holovaty>, <Author: Jacob Kaplan‐Moss>]>>> b.authors.filter(first_name='Adrian')[<Author: Adrian Holovaty>]>>> b.authors.filter(first_name='Adam')[]

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

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

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

参考:django官方文档

0 0
原创粉丝点击