Django中ORM多对多表的操作
自己创建第三张表建立多对多关系
表的创建
# 老师表和学生表可以是一个多对多的关系,建表时可以手动建立第三张表建立关联 class Student(models.Model):
name = models.CharField(max_length=32, null=True)
age = models.CharField(max_length=32, null=True) class Teacher(models.Model):
name = models.CharField(max_length=32, null=True)
gender = models.CharField(max_length=32, null=True) # 建立第三张表,把前两张表关联起来
class TeacherToStudent(models.Model):
stu = models.ForeignKey('Student', null=True)
teac = models.ForeignKey('Teacher', null=True)
增删改查的操作
# 增 直接通过models.类名.objects.create进行添加
models.Student.objects.create(name="xxx",age=12)
models.Teacher.objects.create(name="ooo",gender="男")
models.TeacherToStudent.objects.create(stu_id=1, teac_id=1) # 删 找出对象.delete() ,并且把对应关系也删了
models.Teacher.objects.filter(id=4).delete()
models.TeacherToStudent.objects.filter(teac_id=4).delete() # 改 一样不同的表分开操作
models.Teacher.objects.filter(id=3).update(name="xoxo") # 查 ,如果我想查询一个学生同时被多少个老师教,有图下三种方法
# 1:
res = models.Student.objects.filter(id=2).all() # 先查出符合条件的学生
for row in res:
print(row.name)
r = row.teachertostudent_set.all() # (反查)表示第三张表中所有学生id为2的行
for i in r:
# i.teac # (正查)表示对应的老师表里的一列
print(i.teac.name) # 查出学生id为2对应的所有老师 # 2:
res = models.TeacherToStudent.objects.filter(stu__name="cao").all()
# 查出来的是学生名字为cao对应的所有的行(神奇的双下划线)
for row in res:
print(row.stu.name, row.teac.name) # 找到学生和老师的对应关系 # 3:
res = models.TeacherToStudent.objects.filter(stu__name="li").values("teac__name")
# 查出来的QuerySet 列表,里面包含字典
print(res)
Django中方法创建多对多关系
表的创建
# 表的创建,创建一个班级和课程的多对多关系
# 通过django中的ManyToManyField创建多对多关系,字段放在两个列中任意一个都可以
class Classes(models.Model):
name = models.CharField(max_length=32, null=True)
course = models.ManyToManyField('Course') class Course(models.Model):
name = models.CharField(max_length=32, null=True)
增删改查的操作
# 增 先要找到对应的班级或者课程对象
obj = models.Classes.objects.filter(id=4).first()
# 找到之后通过建表时的course.add进行添加,要把课程id放在列表里打散传进去
obj.course.add(1) # 增加一个
obj.course.add(*[2,3]) # 增加多个 # 删 找到对象.建表时的属性名.clear() 删除所有
obj = models.Classes.objects.filter(id=4).first()
obj.course.clear() # 重置(改),也是找到对象,通过.set()方法,里面放一个列表
obj = models.Classes.objects.filter(id=3).first()
obj.course.set([1,2,3]) # 查 对于模型类中有ManyToManyField字段的表来说
res = models.Classes.objects.all() # 先查出所有的对象
for row in res:
print(row.name)
for i in row.course.all(): # row.course.all()就是每个班级对应的所有课程对象
print(i.name)
#对于模型类中没有ManyToManyField字段的表来说
res = models.Course.objects.all() # 也是先查出所有的对象
for row in res:
print("===================")
print(row.name)
for i in row.classes_set.all(): # 每个学科对应的所有班级
print(i.name)
注:这两种方法建立多对多关系都是可以的,分情况考虑用哪一个,如果表之间的关系简单,
第三张表中不需要加入除两张表id以外的字段可以用django创建但是如果表关系比较复杂,
并且,第三张表中还需要加入一些其他的字段,就需要用到我们自定义的多对多关系(
手动创建第三张表),可以自定制第三张表的结构
Django中ORM多对多表的操作的更多相关文章
- Django中ORM系统多表数据操作
一,多表操作之增删改查 1.在seting.py文件中配置数据库连接信息 2.创建数据库关联关系models.py from django.db import models # Create your ...
- Django之ORM多对多表创建方式,AJAX异步提交,分页器组件等
MTV与MVC MTV模型: M:模型层(models.py),负责业务对象和数据库关系的映射(ORM) T:模板层(Template),负责如何把页面展示给用户(HTML) V:视图层( ...
- Django中ORM创建表关系
一:django中ORM创建表关系 ORM创建外键关系 1.表与表之间的关系 1.表与表之间的关系 一对多 一对一 多对多 2.操作目标条件: 图书表 出版社表 作者表 作者详情表 3.外键关联 一对 ...
- 6月20日 Django中ORM介绍和字段、字段参数、相关操作
一.Django中ORM介绍和字段及字段参数 二.Django ORM 常用字段和参数 三.Django ORM执行原生SQL.在Python脚本中调用Django环境.Django终端打印SQL语句 ...
- Django中ORM介绍和字段及其参数
ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...
- Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM)
Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...
- Django中ORM对数据库的增删改查
Django中ORM对数据库数据的增删改查 模板语言 {% for line in press %} {% line.name %} {% endfor %} {% if 条件 %}{% else % ...
- 【Django】ajax(多对多表单)
1.前后端交互 <div class="shade hide"></div> <!--遮罩层,全屏--> <div class=" ...
- Django中ORM的使用
Django中ORM的使用 ORM orm(object-relation-mapping)对象关系映射,即用对象来表示关系数据库中的表: 类 --> 表, 对象-->一行数据 对象的属性 ...
随机推荐
- linux普通用户添加root权限
新增一个普通用户并进入该用户: [root@VM_0_7_centos ~]# groupadd mall [root@VM_0_7_centos ~]# useradd mall -m -d /ho ...
- Source Insight解决回车缩进过多问题
摘自:https://jingyan.baidu.com/article/02027811339e651bcc9ce53c.html 新安装的Source Insight软件在编写代码时,回车换行 ...
- mysql登录指令
mysql -h 192.168.1.124 -u root -p -h后加mysql的ip,-u加用户名,-p会弹出输入密码
- WebService学习总结(三)——使用JDK开发WebService(转)
一.WebService的开发手段 使用Java开发WebService时可以使用以下两种开发手段 1. 使用JDK开发(1.6及以上版本) 2.使用CXF框架开发(工作中) 二.使用JDK开发Web ...
- vue react 路由history模式刷新404问题解决方案
vue单页因微信分享和自动登录需要,对于URL中存在’#’的地址,处理起来比较坑.用history模式就不会存在这样的问题.但是换成history模式,就会有个新的问题,就是页面刷新后,页面就无法显示 ...
- iOS 多线程的简单理解(3)执行方式 + 执行对列 的组合
通过对前面两偏线程理解的总结,自己对线程的理解也逐渐加深,梳理的清晰起来…… 通常在使用线程 的时候,都是要用到 执行对列,执行方式,执行任务, 现在开始新一轮的深入 3. 1. 1 同步 + 串行 ...
- Flutter 一些常用第三方库、插件
网络请求 http ^0.12.0+2 https://pub.dev/packages/http https://github.com/dart-lang/http 该软件包包含一组高级函数和类,可 ...
- PHP 数据库连接
$db = new MySQLi("localhost","root","123","php0307"); !mysql ...
- 计算机视觉/图像处理工具箱推荐(转自cvnote)
最近在几个地方都看到有人问C++下用什么矩阵运算库比较好,顺便做了个调查,做一些相关的推荐吧.主要针对稠密矩阵,有时间会再写一个稀疏矩阵的推荐. Armadillo:C++下的Matlab替代品 地址 ...
- js里typeof和instanceof和箭头表达式要注意的地方,以及其他
如果学过类似C#这样的语言,然后定义两个类class Mu{}和class Ku{},那么显然typeof Mu != typeof Ku的,但是在js里则不是这样,对于Mu和Ku的对象进行typeo ...