一、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. jQuery的优缺点,与vue的不同,vue的优缺点?

    jq优点: 比原生js更易书写, 封装了很多api, 有丰富的插件库; 缺点: 每次升级与之前版本不兼容, 只能手动开发, 操作DOM很慢, 不方便, 变量名污染, 作用域混淆等. vue优缺点: 双 ...

  2. SpringCloud和Dubbo?

    SpringCloud和Dubbo都是现在主流的微服务架构SpringCloud是Apache旗下的Spring体系下的微服务解决方案Dubbo是阿里系的分布式服务治理框架从技术维度上,其实Sprin ...

  3. String 和 StringBuilder、StringBuffer 的区别?

    Java 平台提供了两种类型的字符串:String 和 StringBuffer/StringBuilder,它 们可以储存和操作字符串.其中 String 是只读字符串,也就意味着 String 引 ...

  4. Python - set类型

  5. 理解OIDC协议和认证机制

    当互联网应用越来越多,每个应用程序都实现了自己的身份存储.认证和授权,用户需要在应用上反复的注册与登录,体验糟糕,用户身份信息无法在多个应用间共享与同步.当使用企业应用时,企业提供了一系列应用,尽管是 ...

  6. 机器学习 machine learn

    机器学习 机器学习 概述 什么是机器学习 机器学习是一门能够让编程计算机从数据中学习的计算机科学.一个计算机程序在完成任务T之后,获得经验E,其表现效果为P,如果任务T的性能表现,也就是用以衡量的P, ...

  7. html实体编码遇上js代码

    单双引号 在js代码中 在js中单.双引号引起来的是字符串,如果我们要在字符串中使用单.双引号,需要反斜杠进行转义 let str='user\'s name'; // or let str=&quo ...

  8. 一份你可以在 <head> 里设置的列表

    A list of everything that could go in the <head> of your document github 原地址:https://github.co ...

  9. SQL之总结(一)

    导游通项目之总结SQL 1.选择前面的某几个 oracle:  select * from tb_article where rownum<5 order by article_id       ...

  10. HTML5 Audio & Video 属性解析

    一.HTML 音频/视频 方法 play() play() 方法开始播放当前的音频或视频. var myVideo=document.getElementById("video1" ...