天天看點

django ManyToManyField多對多關系

Django 的 ORM 有多種關系:一對一,多對一,多對多

各自定義的方式為 :

一對一: OneToOneField

多對一: ForeignKey

多對多: ManyToManyField

上邊的描述太過資料而缺乏人性化,我們來更人性化一些:

       多個屬于一個,即 belong to :  ForeignKey,多個屬于一個

       一個有一個,即 has one: OneToOneField

       一個有很多個,即 has many:  lots of A belong to B 與 B has many A,在建立 ForeignKey 時,另一個表會自動建立對應的關系

       一個既有很多個,又屬于很多個,即 has many and belong to : ManyToManyField,同樣隻能在一個model類中說明,關聯表會自動建立。

多對多的關系:

舉例:現有兩張表,user表和group表。user表中的字段有使用者名,郵箱,年齡等資訊。而group表中有組名資訊。我們知道一個使用者可以屬于多個組,一個組中也可以包含多個使用者,是以這兩張表的關系就是多對多的關系。

mysite/learn/models.py檔案代碼

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<code>#coding:utf8</code>

<code>from</code> <code>django.db </code><code>import</code> <code>models</code>

<code>class</code> <code>Group(models.Model):</code>

<code>    </code><code>Name </code><code>=</code> <code>models.CharField(max_length</code><code>=</code><code>20</code><code>)</code>

<code>    </code><code>def</code> <code>__unicode__(</code><code>self</code><code>):</code>

<code>        </code><code>return</code> <code>self</code><code>.Name</code>

<code>        </code> 

<code>class</code> <code>User(models.Model):</code>

<code>    </code><code>Email </code><code>=</code> <code>models.CharField(max_length</code><code>=</code><code>50</code><code>)</code>

<code>    </code><code>group </code><code>=</code> <code>models.ManyToManyField(Group,blank</code><code>=</code><code>True</code><code>)</code>

<code>    </code><code>def</code> <code>group_list(</code><code>self</code><code>):</code>

<code>        </code><code>return</code> <code>','</code><code>.join([i.Name </code><code>for</code> <code>i </code><code>in</code> <code>self</code><code>.group.</code><code>all</code><code>()])</code>

建立兩張表Group和User,Group表中隻有組名“Name”這一個字段。而User表中有使用者名“Name”,郵箱“Email”,組名“group”三個字段。

在User表中,由于group資訊與Group表關聯的,是以要在User表中設定

<code>ManyToManyField</code>

<code>def</code> <code>group_list(</code><code>self</code><code>):</code>

定義group_list函數,是為了在背景頁面中顯示group_list字段資訊。group_list是背景頁面顯示的字段名稱。

<code>i.Name </code><code>for</code> <code>i </code><code>in</code> <code>self</code><code>.group.</code><code>all</code><code>()</code>

這裡Name是Group表中的Name字段,self.group中的group是User表自己的group字段

mysite/admin.py檔案中的代碼

<code>from</code> <code>django.contrib </code><code>import</code> <code>admin</code>

<code>from</code> <code>learn.models </code><code>import</code> <code>*</code>

<code># Register your models here.</code>

<code>class</code> <code>UserAdmin(admin.ModelAdmin):</code>

<code>    </code><code>list_display </code><code>=</code> <code>[</code><code>'id'</code><code>,</code><code>'Name'</code><code>,</code><code>'Email'</code><code>,</code><code>'group_list'</code><code>]</code>

<code>admin.site.register(User,UserAdmin)</code>

<code>class</code> <code>GroupAdmin(admin.ModelAdmin):</code>

<code>    </code><code>list_display </code><code>=</code> <code>[</code><code>'id'</code><code>,</code><code>'Name'</code><code>]</code>

<code>admin.site.register(Group,GroupAdmin)</code>

通路admin背景管理頁面

在group表中建立組

<a href="https://s5.51cto.com/wyfs02/M01/8E/1F/wKiom1i2N4rjCM41AACrzd90CFE147.png" target="_blank"></a>

<a href="https://s2.51cto.com/wyfs02/M00/8E/1F/wKiom1i2OCmx8T1lAAC2J23EqVg880.png" target="_blank"></a>

仔細看上面的截圖,會發現一個問題--&gt;在Group表中隻有組名字段,但是看不到每個組中都有哪些使用者。而User表中可以看到group_list字段,是以如果希望在Group中顯示使用者資訊,可以仿照User表的做法,mysite/learn/models.py檔案代碼

<code>    </code><code>def</code> <code>user_list(</code><code>self</code><code>):</code>

<code>        </code><code>return</code> <code>','</code><code>.join([i.Name </code><code>for</code> <code>i </code><code>in</code> <code>self</code><code>.user_set.</code><code>all</code><code>()])</code>

<a href="https://s3.51cto.com/wyfs02/M02/8E/1F/wKiom1i2OdegiwDDAAFLXjPfOl8968.png" target="_blank"></a>

在learn/admin.py檔案中加上user_list字段

<a href="https://s2.51cto.com/wyfs02/M01/8E/1F/wKiom1i2OaCBOwHOAAFD7Dtoofc311.png" target="_blank"></a>

再次通路admin背景管理頁面,在group表中可以看到user_list資訊了。

<a href="https://s3.51cto.com/wyfs02/M01/8E/1D/wKioL1i2O23iUglzAADN8Ewl05Y361.png" target="_blank"></a>

正向查詢和反向查詢

正向查詢:

上面我們建立了兩張表user和group,現在我想查詢user表中某個使用者的所屬組

進入django shell指令行

<code>python manage.py shell</code>

<code>&gt;&gt;&gt; </code><code>from</code> <code>learn.models </code><code>import</code> <code>*</code>

<code>&gt;&gt;&gt; User.objects.</code><code>all</code><code>()</code>

<code>[&lt;User: 老黃&gt;, &lt;User: 老張&gt;, &lt;User: 老王&gt;]</code>

<code>&gt;&gt;&gt; User.objects.</code><code>all</code><code>()[</code><code>0</code><code>]</code>

<code>&lt;User: 老黃&gt;</code>

<code>&gt;&gt;&gt; User.objects.</code><code>all</code><code>()[</code><code>0</code><code>].Email</code>

<code>u</code><code>'[email protected]'</code>

<code>&gt;&gt;&gt; User.objects.</code><code>all</code><code>()[</code><code>0</code><code>].group.</code><code>all</code><code>()</code>

<code>[&lt;Group: CEO&gt;, &lt;Group: COO&gt;]</code>

<code>&gt;&gt;&gt; User.objects.</code><code>all</code><code>()[</code><code>0</code><code>].group.</code><code>all</code><code>()[</code><code>0</code><code>].Name</code>

<code>u</code><code>'CEO'</code>

<code>&gt;&gt;&gt; User.objects.</code><code>all</code><code>()[</code><code>0</code><code>].group.</code><code>all</code><code>()[</code><code>0</code><code>].</code><code>id</code>

<code>1</code>

mysite/models.py檔案中的每一個類都是一個對象,使用

<code>User.objects.all()</code>

可以擷取所有對象,它是一個清單

擷取第一個對象

擷取老黃這個對象的郵箱屬性的值

擷取使用者所屬組的組名,和id

反向查詢:

18

19

20

21

22

<code>&gt;&gt;&gt; </code><code>from</code> <code>learn.models </code><code>import</code> <code>*</code>  <code>##導入models中所有的類</code>

<code>&gt;&gt;&gt; Group.objects.</code><code>all</code><code>()   </code><code>##檢視Group表中所有的對象</code>

<code>[&lt;Group: CEO&gt;, &lt;Group: CTO&gt;, &lt;Group: COO&gt;, &lt;Group: VP&gt;]</code>

<code>&gt;&gt;&gt; Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>]  </code><code>##檢視Group表中第一個對象CEO</code>

<code>&lt;Group: CEO&gt;</code>

<code>&gt;&gt;&gt; Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>].Name </code><code>##檢視CEO這個對象的Name屬性</code>

<code>&gt;&gt;&gt; Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>].user_set.</code><code>all</code><code>() </code><code>##反向檢視CEO這個對象的使用者名</code>

<code>[&lt;User: 老黃&gt;]</code>

<code>&gt;&gt;&gt; Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>].user_set.</code><code>all</code><code>()[</code><code>0</code><code>]</code>

<code>&gt;&gt;&gt; Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>].user_set.</code><code>all</code><code>()[</code><code>0</code><code>].Email </code><code>##反向檢視CEO這個對象的Email</code>

<code>&gt;&gt;&gt; Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>].user_set.</code><code>all</code><code>()[</code><code>0</code><code>].Name  </code>

<code>u</code><code>'\u8001\u9ec4'</code>

<code></code>

本文轉自 曾哥最愛 51CTO部落格,原文連結:http://blog.51cto.com/zengestudy/1902277,如需轉載請自行聯系原作者