级联操作
on_delete=None, # 删除关联表中的数据时,该数据也会被删除,不存在
on_delete=models.CASCADE, # 删除关联数据,与之关联也删除
on_delete=models.DO_NOTHING, # 删除关联数据,什么也不做
on_delete=models.PROTECT, # 删除关联数据,保护,引发错误ProtectedError
on_delete=models.SET_NULL, # 删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空)
on_delete=models.SET_DEFAULT, # 删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值)
on_delete=models.SET, # 删除关联数据,
a. 与之关联的值设置为指定值,设置:models.SET(值)
b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)
def func():
return 10
class MyModel(models.Model):
user = models.ForeignKey(
to="User",
to_field="id"
on_delete=models.SET(func),)
创建一张表
# 出版社表
class Press(models.Model):
name = models.CharField(max_length=32)
创建一对多的表
# 书籍表
class Book(models.Model):
name = models.CharField(max_length=32)
Press = models.ForeignKey(Press, on_delete=models.CASCADE) # 默认级联删除
# authors = models.ManyToManyField(Author)
创建多对多的表
# 作者
class Author(models.Model):
name = models.CharField(max_length=32)
sex = models.CharField(max_length=32)
year = models.CharField(max_length=32)
books = models.ManyToManyField(Book) # 多对多关系, 自动创建第三章表