詳解解Django 多對多表關系的三種創建方式

1、方式一:自動創建

# 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)

2、方式二:純手動創建

# 這種方式無法通過orm跨表查詢(不建議使用)

# 表1
class Book(models.Model):
    name = models.CharField(max_length=32)

# 表2
class Author(models.Model):
    name = models.CharField(max_length=32)

# 表3
class Book2Author(models.Model):
    book = models.ForeignKey(to='Book')
    author = models.ForeignKey(to='Author')
    info = models.CharField(max_length=32)

3、方式三:半自動創建

# 可擴展性高,並且能夠符合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)

到此這篇關於詳解解Django 多對多表關系的三種創建方式的文章就介紹到這瞭,更多相關Django創建多對多表關系內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: