目錄
- 1、方式一:自動(dòng)創(chuàng)建
- 2、方式二:純手動(dòng)創(chuàng)建
- 3、方式三:半自動(dòng)創(chuàng)建
1、方式一:自動(dòng)創(chuàng)建
# django orm 自動(dòng)幫我們創(chuàng)建第三張表,我的app名字是app01, 表名為:app01_book_authors
# 這種方式可以讓Django迅速的幫我們建一張關(guān)系表出來(lái),好處是可以通過(guò)這張表進(jìn)行跨表查詢,壞處是一張?zhí)摂M表,拓展性差。
# 書(shū)籍表
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、方式二:純手動(dòng)創(chuàng)建
# 這種方式無(wú)法通過(guò)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、方式三:半自動(dòng)創(chuàng)建
# 可擴(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 書(shū)籍表和作者表的多對(duì)多關(guān)系是通過(guò) Book2Author 表來(lái)記錄的
# through fields 告訴 django orm 記錄關(guān)系是用 Book2Author 表中的 book 字段 和 author字段 來(lái)記錄的
# 此關(guān)系在哪張表寫(xiě)的,through_fields中就優(yōu)先寫(xiě)哪張表(那個(gè)字段)的小寫(xiě)
# 但是,多對(duì)多字段的 add set remove clear 四個(gè)方法就用不了了
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 多對(duì)多表關(guān)系的三種創(chuàng)建方式的文章就介紹到這了,更多相關(guān)Django創(chuàng)建多對(duì)多表關(guān)系內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 教你pycharm運(yùn)行Django第一個(gè)項(xiàng)目
- Django實(shí)現(xiàn)靜態(tài)文件緩存到云服務(wù)的操作方法
- Django動(dòng)態(tài)展示Pyecharts圖表數(shù)據(jù)的幾種方法
- Django將項(xiàng)目移動(dòng)到新環(huán)境的操作步驟
- Django零基礎(chǔ)入門(mén)之路由path和re_path詳解
- Django零基礎(chǔ)入門(mén)之模板變量詳解