您好,登錄后才能下訂單哦!
這篇文章主要講解了“Django多對多表關系的創建方式”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Django多對多表關系的創建方式”吧!
1、方式一:自動創建
2、方式二:純手動創建
3、方式三:半自動創建
# 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跨表查詢(不建議使用) # 表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)
# 可擴展性高,并且能夠符合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多對多表關系的創建方式這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。