A表中的一条记录只能与B表中的一条记录相关联
如:一夫一妻制
允许在关联的两个类的任何一个类中 增加:
属性 = models.OneToOneField(Entry)
class Author(models.Model):
name = models.CharField('姓名',max_length=11)
class Wife(models.Model):
name = models.CharField('姓名',max_length=11)
author=models.OneToOneField(Author)
创建数据
al = Author.objects.create ( name= ' wang ' )
wl = wife.objects.create(name=' wangfuren ' , author=a1)
查询
#1、正向查询:通过wife 找 author
wife = Wife.objects.get(id=1)
author = wife.author
#2、反向查询:通过author 找 wife
#wife 是Django通过OneToOneField在Author中默认增加的一个隐式属性
author=Author.objects.get(id=14)
wife = author.wife
A表中的一条数据可以与B表中的多条数据关联
B表中的一条数据只能与A表中的一条数据关联
如:出版社(Publisher) 和 图书(Book)
商品类型(GoodsType) 和 商品(Goods)
通过外键(ForeignKey)来体现一对多
在"多"表中增加外键(ForeignKey)对"一"表的主键进行引用
使用外键(ForeignKey)
在"多"的实体中,增加:
属性=models.ForeignKey(Entry)
from django.db import models
# Create your models here.
class Publisher( models.Model ):
#出版社[一]
name = models.CharField( '出版社名称',max_length=50)
class Book ( models.Model):
#书名[多]
title = models.CharField('书名',max_length=11)
publisher = models.ForeignKey(Publisher, on_delete=models.CASCADE)
创建数据
from .models import *
pub1 = Publisher.objects.create(name='轻工业出版社')
#两种创建方式
Book.objects.create(title='C++', publisher=pub1)
Book.objects.create(title='Java", publisher_id=1)
查询
#1、正向查询 - 通过Book查询Publisher
book = Book.objects.get(id=1)
publisher = book.publisher
#2、反向查询 - 通过Publisher查询Book
#Django会在 1 的实体中增加 关联对象_set 属性,用于查询 多 的数据
#结合 Publisher 和 Book 之间关系 :在 Publisher实体中增加了一个 book_set 属性
publisher=Publisher.objects.get(id=1)
books = publisher.book_set.all()
A表中的一条记录可以与B表中的任意多条记录匹配
B表中的一条记录可以与A表中的任意多条记录匹配
如:作者与书籍
必须创建第三张表,关联涉及到的两张表数据
Django自动生成第三张表
允许在任何一个实体中增加操作:
entry = models.ManyToManyField(Entry)
from django.db import models
# Create your models here.
class Author( models.Model):
name = models.CharField('姓名',max_length=11)
class Book(models.Model):
title = models.CharField( '书名',max_length=11)
authors = models.ManyToManyField(Author)
创建数据
方案1先创建author 再关联book
author1 = Author.objects.create (name='牛老师')
author2 = Author.objects.create(name='刘老师')
#牛老师和刘老师同时写了一本Python
#两种创建方式
book11 = author1.book_set.create(title="Python")
author2 .book_set.add (book11)
方案2先创建book再关联author
book = Book.objects.create(title= 'python')
#两种创建方式
author3 = book.authors.create(name='宋老师')
book.authors.add(author1)
查询
1、正向查询-通过Author查询所有的Book
author = Author.objects.get(id=1)
books = author.book.all()
2、反向查询-通过Book查询所有的Author
Django中 会在Book 实体中增加一个隐式属性 author_set
book = Book.objects.get(id=1)
authors = book.author_set.all()