Django ORM – 多表实例
表与表之间的关系可分为以下三种:
- 一对一: 一个人对应一个身份证号码,数据字段设置 unique。
- 一对多: 一个家庭有多个人,一般通过外键来实现。
- 多对多: 一个学生有多门课程,一个课程有很多学生,一般通过第三个表来实现关联。
创建模型
接下来我们来看下多表多实例。
from django.db import models
class Book(models.Model):
id = models.AutoField(primary_key=True) # id 会自动创建,可以手动写入
title = models.CharField(max_length=32) # 书籍名称
price = models.DecimalField(max_digits=5, decimal_places=2) # 书籍价格
publish = models.CharField(max_length=32) # 出版社名称
pub_date = models.DateField() # 出版时间
class Publish(models.Model):
name = models.CharField(max_length=32)
city = models.CharField(max_length=64)
email = models.EmailField()
class Author(models.Model):
name = models.CharField(max_length=32)
age = models.SmallIntegerField()
au_detail = models.OneToOneField("AuthorDetail", on_delete=models.CASCADE)
class AuthorDetail(models.Model):
gender_choices = (
(0, "女"),
(1, "男"),
(2, "保密"),
)
gender = models.SmallIntegerField(choices=gender_choices)
tel = models.CharField(max_length=32)
addr = models.CharField(max_length=64)
birthday = models.DateField()
说明:
- 1、EmailField 数据类型是邮箱格式,底层继承 CharField,进行了封装,相当于 MySQL 中的 varchar。
- 2、Django1.1 版本不需要联级删除:on_delete=models.CASCADE,Django2.2 需要。
- 3、一般不需要设置联级更新.
- 4、外键在一对多的多中设置:models.ForeignKey(“关联类名”, on_delete=models.CASCADE)。
- 5、OneToOneField = ForeignKey(…,unique=True)设置一对一。
- 6、若有模型类存在外键,创建数据时,要先创建外键关联的模型类的数据,不然创建包含外键的模型类的数据时,外键的关联模型类的数据会找不到。
表结构
书籍表 Book:title 、 price 、 pub_date 、 publish(外键,多对一) 、 authors(多对多)
出版社表 Publish:name 、 city 、 email
作者表 Author:name 、 age 、 au_detail(一对一)
作者详情表 AuthorDetail:gender 、 tel 、 addr 、 birthday
以下是表格关联说明:
ORM - 添加数据
一对多(外键 ForeignKey)
方式一: 传对象的形式,返回值的数据类型是对象,书籍对象。
步骤:
- a. 获取出版社对象
- b. 给书籍的出版社属性 pulish 传出版社对象
Hello/Hello/views.py 文件代码:
def select_book_obj(request):
# 获取出版社对象
pub_obj = models.Publish.objects.get(id=1).name
print("first-----", pub_obj)
# 给书籍的出版社属性publish传出版社对象
book = models.Book.objects.create(title="杨远", price=200, pub_date="2020-10-10", publish=pub_obj)
print(book, type(book))
print(book.price)
return HttpResponse(book)
运行结果: