一、A表男生,B表女生,C表关系

1通过A表查与某个男生有关系的所有女生

思想1:在A表中确认男生后,通过反查到C表,获取相关内容(QuerySet),然后再跨到B表获取所有女生信息。

obj=models.Boy.objects.filter(name='陈亮').first()
love_list=obj.love_set.all() #love_set.all()反查相关所有(跨表)
for i in love_list: #每个i是一个Love的对象,里面有一个id有一个nick
print(i.g.nick) #g是models里面class里面的属性

思想2:通过C表跨到A表找到对应男生,然后再跨到B表找到女生

 love_list=models.Love.objects.filter(b__name='陈亮')  #这个是b__跨表查询
for i in love_list:
print(i.g.nick, love_list) #这个是按照.类里面的名字查询

二、A表男生,B表女生,自动创建C表ManyToManyField

class Boy(models.Model):
name = models.CharField(max_length=32)
m=models.ManyToManyField('Girl') # 让其自动创建一个表

通过boy表查对应的girl

  obj=models.Boy.objects.filter(name='陈亮').first()
# obj.m.add(2,3) #添加新关系
# obj.m.clear() #把跟name='陈亮‘有关的全部删除
girl_list=obj.m.all() #直接通过.m就查到女孩相关所有
#girl_list = obj.m.filter(二次筛选)
for i in girl_list:
print(i.id,i.nick)

通过girl反查对应的男孩

oss = models.Girl.objects.filter(nick='小猫').first()
a=oss.boy_set.all() #跨表查询
for i in a:
print(i.name)

三、A表男女混合表,B表关系表

&&&

思路:男女信息(名字,性别等)都放在一个表,另外一个表(两个属性)放一个男生的外键(记录男生id)放一个女生的外键(记录女生的id)

问题:反查的时候需要两个外键不知所措(之前的都是一个外键)

解决方法:related_query_name或者related_name(更简单)

g=models.ForeignKey('Boy_and_girl',related_name='boys',on_delete=models.CASCADE,null=True) 

#以前跨表需要写上obj.小写的表名_set.all 比如obj.boy_set.all(),用了**后就不用写小写的表名_set了

#related_query_name   关联的是哪个ForeignKey

#obj对象男.girl_set.all()   把这个名字换成related_query_name的名字

#obj对象女.boy_set.all()   #默认表明+_set

#related_name  更简单

#obj对象男.girl.all()   这种方法改名可以直接写b.all()
获取有关联的所有女性表

#obj对象女.boy.all()

从男女混合表中查到具体人对应所有的有关系的异性

obj=models.Boy_and_girl.objects.filter(id=3).first() #对象
if obj.gender==1:
bb=obj.girls.all() #根据对象反向查找到跟对象有关的所有信息(在另外一张表上)
for i in bb:
print(i.g.nickname) #再带着相关信息(女孩)回到原来的表再查询
else:
bb = obj.boys.all()
for i in bb:
print(i.b.nickname)

四、A表男女混合表(从一张表开始)FK自关联

&&&

思路:男女混合表,在同一张表自动生成另外一张自己与自己相关联的表(类似于

class Boy_and_girl (models.Model):
name = models.CharField(max_length=32)
m=models.ManyToManyField(' Boy_and_girl ',related_name='boy') obj=models.Boy. Boy_and_girl.filter(id=1).first() #找的id=1是男生 girl_list=obj.m.all() #以左边为条件去查,(一共有左(男生)右(女生)两个选项,从左查为正查,从右查为反查) for i in girl_list:
print(i.nickname) #若是这个obj是属于右边选项的,想要反查左边的,得用小写表名_set来进行反查比如: obj. boy_and_girl_set.all() 或者obj.boy.all()

ps:

class Love(models.Model):
b=models.ForeignKey('Boy',on_delete=models.CASCADE,null=True)
g=models.ForeignKey('Girl',on_delete=models.CASCADE,null=True) class Meta: #额外多做了一个约束
unique_together=[
('b','g')
]

Django model中的class Meta详解

Django-ORM-连表正反操作的更多相关文章

  1. Django ORM 多表操作

    目录 Django ORM 多表操作 表模型 表关系 创建模型 逆向到表模型 插入数据 ORM 添加数据(添加外键) 一对多(外键 ForeignKey) 一对一 (OneToOneFeild) 多对 ...

  2. day52:django:ORM单表/多表操作

    目录 1.ORM 2.ORM单表增删改查 13个必知必会的查询接口 filter基于双下划线的模糊查询 3.ORM多表增删改查 ORM 什么是ORM? ORM(object relational ma ...

  3. django ORM模型表的一对多、多对多关系、万能双下划线查询

    一.外键使用 在 MySQL 中,如果使用InnoDB引擎,则支持外键约束.(另一种常用的MyIsam引擎不支持外键) 定义外键的语法为fieldname=models.ForeignKey(to_c ...

  4. Django之mysql表单操作

    在Django之ORM模型中总结过django下mysql表的创建操作,接下来总结mysql表记录操作,包括表记录的增.删.改.查. 1. 添加表记录 class UserInfo(models.Mo ...

  5. Django ORM --- 建表、查询、删除基础

    1.什么是ORM ORM的全称是Object Relational Mapping,即对象关系映射.它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的 ...

  6. django -- ORM建表

    前戏 ORM(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. ORM的优势: ORM解决的主要问题是对象和关系的映射 ...

  7. Django ORM相关的一些操作

    一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 ...

  8. Django之form表单操作

    小白必会三板斧 from django.shortcuts import render,HttpResponse,redirect HttpRespone:返回字符串 render:返回html页面 ...

  9. Django ORM多表查询练习

    ORM多表查询 创建表结构: from django.db import models # 创建表结构 # Create your models here. class Class_grade(mod ...

  10. django ORM 连表查询

    db_index=True  如果设置该字段就可以设置索引 auto_now_add  代表设置创建时候的时间 auto_now   每次更新数据记录时会更新该字段 to_field 设置要关联表的字 ...

随机推荐

  1. 如何获取 topic 主题的列表?

    bin/kafka-topics.sh --list --zookeeper localhost:2181

  2. CSS 网站布局

    Flex:https://www.html.cn/archives/8629 Grid:https://www.html.cn/archives/8510/    http://www.ruanyif ...

  3. idea使用maven工程创建web项目并支持jsp

    主要要再pom文件里面添加依赖: <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api --> & ...

  4. Spring 切面可以应用五种类型的通知?

    Spring 切面可以应用五种类型的通知: before:前置通知,在一个方法执行前被调用. after: 在方法执行之后调用的通知,无论方法执行是否成功. after-returning: 仅当方法 ...

  5. 学习zabbix(六)

    实验环境 实验用2到2台机器,实验所用机器系统环境如下,可以看到2台机器的主机名和IP地址 ? 1 2 3 4 5 6 7 8 9 10 [root@linux-node1 ~]# cat /etc/ ...

  6. 学习GlusterFS(四)

    基于 GlusterFS 实现 Docker 集群的分布式存储 以 Docker 为代表的容器技术在云计算领域正扮演着越来越重要的角色,甚至一度被认为是虚拟化技术的替代品.企业级的容器应用常常需要将重 ...

  7. 安装TypeScript

    安装TypeScript 创建工程文件夹:mkdir <project folder> 进入工程文件夹:cd <project folder> 快速创建程序包:npm init ...

  8. 玩转 React(四)- 创造一个新的 HTML 标签

    在第二篇文章 <新型前端开发方式> 中有说到 React 有很爽的一点就是给我们一种创造 HTML 标签的能力,那么今天这篇文章就详细讲解下 React 是如何提供这种能力的,作为前端开发 ...

  9. 介绍一项让 React 可以与 Vue 抗衡的技术

    好吧,我承认我是标题党.React 明明如日中天,把它与 Vue 倒过来,给 Vue 加点东西或可与 React 抗衡.不过,这两年 Vue 干的正是这事,不断加东西,不断优化,按它现有发展速度超越 ...

  10. Web缓存总结

    web缓存作用 减少网络带宽消耗降低服务器压力减少网络延迟,加快页面打开速度 Web缓存的类型 数据库数据缓存:为了提供查询的性能,会将查询后的数据放到内存中进行缓存,下次查询时,直接从内存缓存直接返 ...