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>
仔细看上面的截图,会发现一个问题-->在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>>>> </code><code>from</code> <code>learn.models </code><code>import</code> <code>*</code>
<code>>>> User.objects.</code><code>all</code><code>()</code>
<code>[<User: 老黄>, <User: 老张>, <User: 老王>]</code>
<code>>>> User.objects.</code><code>all</code><code>()[</code><code>0</code><code>]</code>
<code><User: 老黄></code>
<code>>>> User.objects.</code><code>all</code><code>()[</code><code>0</code><code>].Email</code>
<code>u</code><code>'[email protected]'</code>
<code>>>> User.objects.</code><code>all</code><code>()[</code><code>0</code><code>].group.</code><code>all</code><code>()</code>
<code>[<Group: CEO>, <Group: COO>]</code>
<code>>>> 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>>>> 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>>>> </code><code>from</code> <code>learn.models </code><code>import</code> <code>*</code> <code>##导入models中所有的类</code>
<code>>>> Group.objects.</code><code>all</code><code>() </code><code>##查看Group表中所有的对象</code>
<code>[<Group: CEO>, <Group: CTO>, <Group: COO>, <Group: VP>]</code>
<code>>>> Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>] </code><code>##查看Group表中第一个对象CEO</code>
<code><Group: CEO></code>
<code>>>> Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>].Name </code><code>##查看CEO这个对象的Name属性</code>
<code>>>> Group.objects.</code><code>all</code><code>()[</code><code>0</code><code>].user_set.</code><code>all</code><code>() </code><code>##反向查看CEO这个对象的用户名</code>
<code>[<User: 老黄>]</code>
<code>>>> 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>>>> 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>>>> 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,如需转载请自行联系原作者