詳解解Django 多對多表關系的三種創(chuàng)建方式
更新時間:2021年08月22日 15:24:29 作者:秋刀魚的滋味w
本文主要介紹了詳解解Django 多對多表關系的三種創(chuàng)建方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
1、方式一:自動創(chuàng)建
# django orm 自動幫我們創(chuàng)建第三張表,我的app名字是app01, 表名為:app01_book_authors # 這種方式可以讓Django迅速的幫我們建一張關系表出來,好處是可以通過這張表進行跨表查詢,壞處是一張?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)
2、方式二:純手動創(chuàng)建
# 這種方式無法通過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、方式三:半自動創(chuàng)建
# 可擴展性高,并且能夠符合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 書籍表和作者表的多對多關系是通過 Book2Author 表來記錄的 # through fields 告訴 django orm 記錄關系是用 Book2Author 表中的 book 字段 和 author字段 來記錄的 # 此關系在哪張表寫的,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)
到此這篇關于詳解解Django 多對多表關系的三種創(chuàng)建方式的文章就介紹到這了,更多相關Django創(chuàng)建多對多表關系內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Pandas數(shù)據(jù)分析之pandas文本處理
這篇文章主要介紹了Pandas數(shù)據(jù)分析之pandas文本處理,pandas對文本數(shù)據(jù)也有很多便捷處理方法,可以不用寫循環(huán),向量化操作運算速度快,還可以進行高級的正則表達式,各種復雜的邏輯篩選和匹配提取信息2022-08-08matplotlib之pyplot模塊坐標軸標簽設置使用(xlabel()、ylabel())
這篇文章主要介紹了matplotlib之pyplot模塊坐標軸標簽設置使用(xlabel()、ylabel()),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02Python函數(shù)命名空間,作用域LEGB及Global詳析
這篇文章主要介紹了Python函數(shù)命名空間,作用域LEGB及Global詳析,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-09-09Python中常用數(shù)據(jù)類型使用示例概括總結(jié)
這篇文章主要為大家介紹了Python中常用數(shù)據(jù)類型使用示例概括總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04python django事務transaction源碼分析詳解
這篇文章主要介紹了python django事務transaction源碼分析詳解的相關資料,需要的朋友可以參考下2017-03-03