成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

如何分析djangomodels中的M對N關(guān)系

如何分析django models中的M對N關(guān)系,針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

創(chuàng)新互聯(lián)建站是一家專注于成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),金安網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)建站做網(wǎng)站,專注于網(wǎng)站建設(shè)10余年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:金安等地區(qū)。金安做網(wǎng)站價(jià)格咨詢:18982081108

下面介紹django models三種關(guān)系模型中的M對N關(guān)系:

M對N模型

在sql語言中,M:N關(guān)系是通過建立一個(gè)中間關(guān)系表來完成,該中間表定義了到兩個(gè)主表的外鍵。所以也可以用兩個(gè)1:N來定義M:N.

    同時(shí)django模型定義了一種更直接的M:N關(guān)系的建模方式,即在兩個(gè)模型中的任意一個(gè)中定義models,ManyToManyField類型的字段

多對多關(guān)系:

        1、直接定義ManyToManyField字段 

                class  Author(models.Model):

                      name =models.CharField(max_length=100)

                 class  Book(models.Model):

                     title =models.CharField(max_length=100)

                     authors =models.ManyToManyField(Author)

                     book= Book.objects.get(title="Django")

                     authors = Book.author_set.all()  # 獲取該書的作者名單

                     books= author[2].book_set.all() # 獲取第三作者所著的所有圖書

        2、通過中間表定義

               class  Book(models.Model):

                     title =models.CharField(max_length=100)

                     authors =models.ManyToManyField(Author, through="Authoring")

               class   Authoring(models.Model):

                     collaboration_type =models.CharField(max_length=100)

                     book =models.ForeignKey(Book)

                     author =models.ForeignKey(Author)

                 chun_essay_compilations = Book.objects.filter(

                        author__name__endswith='Chun',

                        authoring__collaboration_type='essay'

     )

訪問多對多值(Many-to-Many Values)

多對多和外鍵工作方式相同,只不過我們處理的是QuerySet而不是模型實(shí)例。 例如,這里是如何查看書籍的作者:

>>> b = Book.objects.get(id=50)
>>> b.authors.all()
[<Author: Adrian Holovaty>, <Author: Jacob Kaplan-Moss>]
>>> b.authors.filter(first_name='Adrian')
[<Author: Adrian Holovaty>]
>>> b.authors.filter(first_name='Adam')
[]

反向查詢也可以。 要查看一個(gè)作者的所有書籍,使用author.book_set ,就如這樣:

>>> a = Author.objects.get(first_name='Adrian', last_name='Holovaty')
>>> a.book_set.all()
[<Book: The Django Book>, <Book: Adrian's Other Book>]

這里,就像使用 ForeignKey字段一樣,屬性名book_set是在數(shù)據(jù)模型(model)名后追加_set

關(guān)于如何分析django models中的M對N關(guān)系問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

分享題目:如何分析djangomodels中的M對N關(guān)系
標(biāo)題URL:http://jinyejixie.com/article18/jjhsgp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站小程序開發(fā)、網(wǎng)站策劃網(wǎng)站建設(shè)、域名注冊企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
克什克腾旗| 枣庄市| 衡阳县| 新宾| 个旧市| 六枝特区| 景宁| 镇坪县| 景宁| 文登市| 黄石市| 昆山市| 玛纳斯县| 忻城县| 汕头市| 邵武市| 平凉市| 永济市| 柘城县| 泽普县| 冀州市| 新昌县| 衡山县| 华宁县| 腾冲县| 彝良县| 安西县| 元朗区| 石柱| 滦南县| 阿尔山市| 肇东市| 大石桥市| 兴化市| 伊通| 杂多县| 浏阳市| 永嘉县| 明星| 黄陵县| 泸溪县|