Python Django ORM连表正反操作技巧


Posted in Python onJune 13, 2021

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

Python Django ORM连表正反操作技巧Python Django ORM连表正反操作技巧Python Django ORM连表正反操作技巧Python Django ORM连表正反操作技巧

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

Python Django ORM连表正反操作技巧Python Django ORM连表正反操作技巧Python Django ORM连表正反操作技巧Python Django ORM连表正反操作技巧

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表关系表

Python Django ORM连表正反操作技巧&&&Python Django ORM连表正反操作技巧

Python Django ORM连表正反操作技巧Python Django ORM连表正反操作技巧

思路:男女信息(名字,性别等)都放在一个表,另外一个表(两个属性)放一个男生的外键(记录男生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自关联

Python Django ORM连表正反操作技巧&&&Python Django ORM连表正反操作技巧

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

以上就是Django-ORM-连表正反操作的详细内容,更多关于Django-ORM-连表正反操作的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python中查看变量内存地址的方法
May 05 Python
Python编程实现控制cmd命令行显示颜色的方法示例
Aug 14 Python
对变量赋值的理解--Pyton中让两个值互换的实现方法
Nov 29 Python
python筛选出两个文件中重复行的方法
May 31 Python
python 用lambda函数替换for循环的方法
Jun 09 Python
python实现将文件夹下面的不是以py文件结尾的文件都过滤掉的方法
Oct 21 Python
python实现连续图文识别
Dec 18 Python
Django的models中on_delete参数详解
Jul 16 Python
解决django服务器重启端口被占用的问题
Jul 26 Python
Python Django实现layui风格+django分页功能的例子
Aug 29 Python
使用Python制作缩放自如的圣诞老人(圣诞树)
Dec 25 Python
PyCharm永久激活方式(推荐)
Sep 22 Python
Python scrapy爬取起点中文网小说榜单
教你用Python爬取英雄联盟皮肤原画
使用qt quick-ListView仿微信好友列表和聊天列表的示例代码
python基础入门之普通操作与函数(三)
python基础入门之字典和集合
Python OpenCV实现传统图片格式与base64转换
Jun 13 #Python
python实现A*寻路算法
You might like
PHP初学者头疼问题总结
2006/10/09 PHP
excellent!――ASCII Art(由目标图象生成ascii)
2007/02/20 PHP
php实现微信公众号主动推送消息
2015/12/31 PHP
Zend Framework动作助手Json用法实例分析
2016/03/05 PHP
php中的登陆login实例代码
2016/06/20 PHP
详解php几行代码实现CSV格式文件输出
2017/07/01 PHP
一个封装js代码-----展开收起效果示例
2013/07/03 Javascript
js实现根据身份证号自动生成出生日期
2015/12/15 Javascript
使用堆实现Top K算法(JS实现)
2015/12/25 Javascript
大型JavaScript应用程序架构设计模式
2016/06/29 Javascript
jquery.serialize() 函数语法及简单实例
2016/07/08 Javascript
第一次接触Bootstrap框架
2016/10/24 Javascript
javascript垃圾收集机制的原理分析
2016/12/08 Javascript
谈谈JavaScript数组常用方法总结
2017/01/24 Javascript
js的OOP继承实现(必看篇)
2017/02/18 Javascript
socket.io学习教程之基本应用(二)
2017/04/29 Javascript
js脚本编写简单刷票投票系统
2017/06/27 Javascript
JS如何实现在弹出窗口中加载页面
2020/12/03 Javascript
vue登录页实现使用cookie记住7天密码功能的方法
2021/02/18 Vue.js
[03:17]史诗级大片应援2018DOTA2国际邀请赛 致敬每一位坚守遗迹的勇士
2018/07/20 DOTA
python算法演练_One Rule 算法(详解)
2017/05/17 Python
pygame实现弹力球及其变速效果
2017/07/03 Python
Python实现螺旋矩阵的填充算法示例
2017/12/28 Python
详解如何管理多个Python版本和虚拟环境
2019/05/10 Python
python中从for循环延申到推导式的具体使用
2019/11/29 Python
Python操作Excel把数据分给sheet
2020/05/20 Python
详解Django中views数据查询使用locals()函数进行优化
2020/08/24 Python
C#实现对任一张表的数据进行增,删,改,查要求,运用Webservice,体现出三层架构
2014/07/11 面试题
排序都有哪几种方法?请列举。用JAVA实现一个快速排序
2014/02/16 面试题
电子商务助理求职自荐信
2014/04/10 职场文书
树转促学习心得体会
2014/09/10 职场文书
2015年党建工作总结
2015/03/30 职场文书
2016七一建党节慰问信
2015/11/30 职场文书
SQL Server连接查询的实用教程
2021/04/07 SQL Server
SQL注入详解及防范方法
2021/12/06 MySQL
《艾尔登法环》发布最新「战技」宣传片
2022/04/03 其他游戏