首页 > 编程 > Python > 正文

举例讲解Django中数据模型访问外键值的方法

2020-01-04 18:01:15
字体:
来源:转载
供稿:网友

这篇文章主要介绍了举例讲解Django中数据模型访问外键值的方法,Django是最具人气的Python web开发框架,需要的朋友可以参考下

先设置一个关于书本(book)的数据模型:

 

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

访问外键(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,所以它可以像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组成的。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表