Django 多對多表關係的兩種建立方式
第一種:自動建立
# django orm 自動幫我們建立第三張表,我的app名字是app01, 表名為:app01_book_authors
# 這種方式可以讓Django迅速的幫我們建一張關係表出來,好處是可以通過這張表進行跨表查詢,壞處是一張虛擬表,拓展性差。
# 書籍表
class Book(models.Model):
name = models.CharField(max_length=32)
authors = models.ManyToManyField(to='Author')
# 作者表
class Author(models.Model):
name = models.CharField(max_length=32)
第二種:半自動建立
# 可擴充套件性高,並且能夠符合orm查詢
class Book(models.Model):
name = models.CharField(max_length=32)
# 第三種建立表的方式
authors = models.ManyToManyField(to='Author', through='Book2Author', through_fields=('book', 'author'))
# through 告訴 django orm 書籍表和作者表的多對多關係是通過 Book2Author 表來記錄的
# through fields 告訴 django orm 記錄關係是用 Book2Author 表中的 book 欄位 和 author欄位 來記錄的
# 此關係在哪張表寫的,through_fields中就優先寫哪張表(那個欄位)的小寫
# 但是,多對多欄位的 add set remove clear 四個方法就用不了了
class Author(models.Model):
name = models.CharField(max_length=32)class Book2Author(models.Model):
book = models.ForeignKey(to='Book')
author = models.ForeignKey(to='Author')
info = models.CharField(max_length=32)