欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解解Django 多對多表關(guān)系的三種創(chuàng)建方式

 更新時(shí)間:2021年08月22日 15:24:29   作者:秋刀魚的滋味w  
本文主要介紹了詳解解Django 多對多表關(guān)系的三種創(chuàng)建方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1、方式一:自動(dòng)創(chuàng)建

# django orm 自動(dòng)幫我們創(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)

2、方式二:純手動(dòng)創(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、方式三:半自動(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 書籍表和作者表的多對多關(guān)系是通過 Book2Author 表來記錄的
    # through fields 告訴 django orm 記錄關(guān)系是用 Book2Author 表中的 book 字段 和 author字段 來記錄的
    # 此關(guān)系在哪張表寫的,through_fields中就優(yōu)先寫哪張表(那個(gè)字段)的小寫
    # 但是,多對多字段的 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 多對多表關(guān)系的三種創(chuàng)建方式的文章就介紹到這了,更多相關(guān)Django創(chuàng)建多對多表關(guān)系內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python批量telnet檢測IP地址的端口是否開放

    python批量telnet檢測IP地址的端口是否開放

    本文主要介紹了python批量telnet檢測IP地址的端口是否開放,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • DRF使用simple JWT身份驗(yàn)證的實(shí)現(xiàn)

    DRF使用simple JWT身份驗(yàn)證的實(shí)現(xiàn)

    這篇文章主要介紹了DRF使用simple JWT身份驗(yàn)證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Pandas數(shù)據(jù)分析之pandas文本處理

    Pandas數(shù)據(jù)分析之pandas文本處理

    這篇文章主要介紹了Pandas數(shù)據(jù)分析之pandas文本處理,pandas對文本數(shù)據(jù)也有很多便捷處理方法,可以不用寫循環(huán),向量化操作運(yùn)算速度快,還可以進(jìn)行高級(jí)的正則表達(dá)式,各種復(fù)雜的邏輯篩選和匹配提取信息
    2022-08-08
  • Python學(xué)習(xí)之yaml文件的讀取詳解

    Python學(xué)習(xí)之yaml文件的讀取詳解

    yaml其實(shí)也類似于 json、txt ,它們都屬于一種文本格式。在我們的實(shí)際工作中, yaml 文件經(jīng)常作為服務(wù)期配置文件來使用。本文將為大家介紹一些Python讀取yaml文件的方法,需要的可以參考一下
    2022-03-03
  • 解決Python中定時(shí)任務(wù)線程無法自動(dòng)退出的問題

    解決Python中定時(shí)任務(wù)線程無法自動(dòng)退出的問題

    今天小編就為大家分享一篇解決Python中定時(shí)任務(wù)線程無法自動(dòng)退出的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • matplotlib之pyplot模塊坐標(biāo)軸標(biāo)簽設(shè)置使用(xlabel()、ylabel())

    matplotlib之pyplot模塊坐標(biāo)軸標(biāo)簽設(shè)置使用(xlabel()、ylabel())

    這篇文章主要介紹了matplotlib之pyplot模塊坐標(biāo)軸標(biāo)簽設(shè)置使用(xlabel()、ylabel()),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Python函數(shù)命名空間,作用域LEGB及Global詳析

    Python函數(shù)命名空間,作用域LEGB及Global詳析

    這篇文章主要介紹了Python函數(shù)命名空間,作用域LEGB及Global詳析,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下
    2022-09-09
  • Python中常用數(shù)據(jù)類型使用示例概括總結(jié)

    Python中常用數(shù)據(jù)類型使用示例概括總結(jié)

    這篇文章主要為大家介紹了Python中常用數(shù)據(jù)類型使用示例概括總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 橫向?qū)Ρ确治鯬ython解析XML的四種方式

    橫向?qū)Ρ确治鯬ython解析XML的四種方式

    這篇文章主要以橫向?qū)Ρ确绞椒治鯬ython解析XML的四種方式,感興趣的小伙伴們可以參考一下
    2016-03-03
  • python django事務(wù)transaction源碼分析詳解

    python django事務(wù)transaction源碼分析詳解

    這篇文章主要介紹了python django事務(wù)transaction源碼分析詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03

最新評(píng)論