# django orm 自動幫我們創(chuàng)建第三張表,我的app名字是app01, 表名為:app01_book_authors # 這種方式可以讓Django迅速的幫我們建一張關(guān)系表出來,好處是可以通過這張表進(jìn)行跨表查詢,壞處是一張?zhí)摂M表,拓展性差。 # 書籍表 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跨表查詢(不建議使用) # 表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)
# 可擴(kuò)展性高,并且能夠符合orm查詢 class Book(models.Model): name = models.CharField(max_length=32) # 第三種創(chuàng)建表的方式 authors = models.ManyToManyField(to='Author', through='Book2Author', through_fields=('book', 'author')) # through 告訴 django orm 書籍表和作者表的多對多關(guān)系是通過 Book2Author 表來記錄的 # through fields 告訴 django orm 記錄關(guān)系是用 Book2Author 表中的 book 字段 和 author字段 來記錄的 # 此關(guān)系在哪張表寫的,through_fields中就優(yōu)先寫哪張表(那個字段)的小寫 # 但是,多對多字段的 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)
到此這篇關(guān)于詳解解Django 多對多表關(guān)系的三種創(chuàng)建方式的文章就介紹到這了,更多相關(guān)Django創(chuàng)建多對多表關(guān)系內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:林芝 南平 普洱 漯河 海南 大同 盤錦 寧夏
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解解Django 多對多表關(guān)系的三種創(chuàng)建方式》,本文關(guān)鍵詞 詳,解解,Django,多對,多表,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。