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
- Django笔记 数据库数据外键 多对多关系访问
- Django-数据库多对多关系
- Django数据库多对多数据关系
- django中数据库一对一,一对多,多对多关系
- Django数据库操作中的多对多关系
- Django多对多关系
- django之多对多关系
- Django的学习笔记(三)(Django多对多关系模型)
- django数据库操作-增删改查-多对多关系以及一对多(外键)关系
- django数据库操作-增删改查-多对多关系以及一对多(外键)关系
- django数据库操作-增删改查-多对多关系以及一对多(外键)关系
- django数据库操作-增删改查-多对多关系以及一对多(外键)关系
- Django数据库一对一数据关系
- Django中的数据库模型类-models.py(多对多的关系)
- Django数据库之多对多的创建
- 【Django】建立数据库后访问数据
- Apache sdo学习笔记(六)——数据访问服务(DAS)访问关系数据库
- Django 一对多,多对多关系解析
- Chapter 3 装饰设计模式与Java IO
- Dijkstra + 优先队列 + 邻接表优化
- linux ftp新建用户删除用户以及更改密码
- a
- 【HDU 3887】【dfs序+线段树】Counting Offspring 【查询子树上标号比它小的点有多少个 】
- Django笔记 数据库数据外键 多对多关系访问
- 函数的可重入性理解
- HTTP 请求头与请求体
- 【linux 文件】管道通信,信号通信
- 业余03—MicrosoftOffice激活工具
- android addCategory()等说明
- uboot 分析之 配置+编译过程
- 详解梯度下降法求解线性模型参数
- WCF:并发1