django ManyToManyField多对多关系的实例详解

作者:zenge_blog 时间:2023-08-11 20:21:01 

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文件代码


#coding:utf8
from django.db import models

class Group(models.Model):
 Name = models.CharField(max_length=20)
 def __unicode__(self):
   return self.Name

class User(models.Model):
 Name = models.CharField(max_length=20)
 Email = models.CharField(max_length=50)
 group = models.ManyToManyField(Group,blank=True)
 def __unicode__(self):
   return self.Name
 def group_list(self):
   return ','.join([i.Name for i in self.group.all()])

创建两张表Group和User,Group表中只有组名“Name”这一个字段。而User表中有用户名“Name”,邮箱“Email”,组名“group”三个字段。

在User表中,由于group信息与Group表关联的,所以要在User表中设置


ManyToManyField

def group_list(self):
   return ','.join([i.Name for i in self.group.all()])

定义group_list函数,是为了在后台页面中显示group_list字段信息。group_list是后台页面显示的字段名称。


i.Name for i in self.group.all()

这里Name是Group表中的Name字段,self.group中的group是User表自己的group字段

mysite/admin.py文件中的代码


from django.contrib import admin
from learn.models import *
# Register your models here.

class UserAdmin(admin.ModelAdmin):
 list_display = ['id','Name','Email','group_list']
admin.site.register(User,UserAdmin)

class GroupAdmin(admin.ModelAdmin):
 list_display = ['id','Name']
admin.site.register(Group,GroupAdmin)

访问admin后台管理页面

在group表中创建组

django ManyToManyField多对多关系的实例详解

在user表中创建用户,Group字段选择用户组。

django ManyToManyField多对多关系的实例详解

django ManyToManyField多对多关系的实例详解

仔细看上面的截图,会发现一个问题-->在Group表中只有组名字段,但是看不到每个组中都有哪些用户。而User表中可以看到group_list字段,所以如果希望在Group中显示用户信息,可以仿照User表的做法,mysite/learn/models.py文件代码


#coding:utf8
from django.db import models

class Group(models.Model):
 Name = models.CharField(max_length=20)
 def user_list(self):
   return ','.join([i.Name for i in self.user_set.all()])
 def __unicode__(self):
   return self.Name
class User(models.Model):
 Name = models.CharField(max_length=20)
 Email = models.CharField(max_length=50)
 group = models.ManyToManyField(Group,blank=True)
 def __unicode__(self):
   return self.Name
 def group_list(self):
   return ','.join([i.Name for i in self.group.all()])

django ManyToManyField多对多关系的实例详解

在learn/admin.py文件中加上user_list字段

django ManyToManyField多对多关系的实例详解

再次访问admin后台管理页面,在group表中可以看到user_list信息了。

django ManyToManyField多对多关系的实例详解

正向查询和反向查询

正向查询:

上面我们创建了两张表user和group,现在我想查询user表中某个用户的所属组

进入django shell命令行


python manage.py shell

>>> from learn.models import *
>>> User.objects.all()
[<User: 老黄>, <User: 老张>, <User: 老王>]
>>> User.objects.all()[0]
<User: 老黄>
>>> User.objects.all()[0].Email
u'laohuang@qq.com'
>>> User.objects.all()[0].group.all()
[<Group: CEO>, <Group: COO>]
>>> User.objects.all()[0].group.all()[0].Name
u'CEO'
>>> User.objects.all()[0].group.all()[0].id

mysite/models.py文件中的每一个类都是一个对象,使用


User.objects.all()

可以获取所有对象,它是一个列表


[<User: 老黄>, <User: 老张>, <User: 老王>]

获取第一个对象


>>> User.objects.all()[0]
<User: 老黄>

获取老黄这个对象的邮箱属性的值


>>> User.objects.all()[0].Email
u'laohuang@qq.com'

获取用户所属组的组名,和id


>>> User.objects.all()[0].group.all()[0].Name
u'CEO'
>>> User.objects.all()[0].group.all()[0].id

反向查询:


>>> from learn.models import * ##导入models中所有的类

>>> Group.objects.all()  ##查看Group表中所有的对象
[<Group: CEO>, <Group: CTO>, <Group: COO>, <Group: VP>]

>>> Group.objects.all()[0] ##查看Group表中第一个对象CEO
<Group: CEO>

>>> Group.objects.all()[0].Name ##查看CEO这个对象的Name属性
u'CEO'

>>> Group.objects.all()[0].user_set.all() ##反向查看CEO这个对象的用户名
[<User: 老黄>]

>>> Group.objects.all()[0].user_set.all()[0]
<User: 老黄>

>>> Group.objects.all()[0].user_set.all()[0].Email ##反向查看CEO这个对象的Email
u'laohuang@qq.com'

>>> Group.objects.all()[0].user_set.all()[0].Name
u'\u8001\u9ec4'

来源:https://blog.51cto.com/zengestudy/1902277

标签:django,ManyToManyField,多对多
0
投稿

猜你喜欢

  • kafka rabbitMQ及rocketMQ队列的消息可靠性保证分析

    2022-05-06 08:10:23
  • Python实现字符串格式化的方法小结

    2022-08-14 11:04:02
  • 利用Python将彩色图像转为灰度图像的两种方法

    2021-02-06 05:28:54
  • python函数enumerate,operator和Counter使用技巧实例小结

    2022-08-09 07:02:32
  • 理解JavaScript变量作用域更轻松

    2024-04-16 09:25:07
  • 基于Python获取docx/doc文件内容代码解析

    2022-09-20 09:25:23
  • python b站视频下载的五种版本

    2022-08-18 05:28:25
  • Mysql 5.7 新特性之 json 类型的增删改查操作和用法

    2024-01-24 23:45:53
  • Python如何实现定时器功能

    2023-04-13 23:19:28
  • Golang如何编写内存高效及CPU调优的Go结构体

    2024-04-23 09:45:55
  • asp.net TreeView与XML三步生成列表树

    2024-06-05 09:32:31
  • PyCharm如何配置SSH和SFTP连接远程服务器

    2022-04-27 01:57:28
  • Python导入自定义路径的方法

    2021-06-30 13:43:28
  • 微信小程序点餐系统开发常见问题汇总

    2024-04-10 10:52:00
  • 利用python实现逐步回归

    2023-10-05 19:24:27
  • 在ASP中使用SQL语句之7:ORDER BY

    2007-08-11 12:51:00
  • Pytorch结合PyG实现MLP过程详解

    2022-05-01 21:51:55
  • 一次python-flask蓝图的踩坑记录

    2021-11-04 13:32:35
  • ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法

    2024-04-17 10:39:54
  • python画立方体--魔方

    2022-04-22 10:20:43
  • asp之家 网络编程 m.aspxhome.com