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中使用PDB库调试程序
Apr 05 Python
Python实现随机选择元素功能
Sep 14 Python
Python常见的pandas用法demo示例
Mar 16 Python
Python爬虫 scrapy框架爬取某招聘网存入mongodb解析
Jul 31 Python
python中时间转换datetime和pd.to_datetime详析
Aug 11 Python
Python字符串中添加、插入特定字符的方法
Sep 10 Python
Python爬虫使用浏览器cookies:browsercookie过程解析
Oct 22 Python
django filter过滤器实现显示某个类型指定字段不同值方式
Jul 16 Python
Python调用JavaScript代码的方法
Oct 27 Python
python3代码中实现加法重载的实例
Dec 03 Python
python自动化调用百度api解决验证码
Apr 13 Python
使用python向MongoDB插入时间字段的操作
May 18 Python
Python scrapy爬取起点中文网小说榜单
教你用Python爬取英雄联盟皮肤原画
使用qt quick-ListView仿微信好友列表和聊天列表的示例代码
python基础入门之普通操作与函数(三)
python基础入门之字典和集合
Python OpenCV实现传统图片格式与base64转换
Jun 13 #Python
python实现A*寻路算法
You might like
PHP 下载文件时自动添加bom头的方法实例
2014/01/10 PHP
ThinkPHP标签制作教程
2014/07/10 PHP
PHP中的use关键字概述
2014/07/23 PHP
PHP生成压缩文件实例
2015/02/07 PHP
php发送html格式文本邮件的方法
2015/06/10 PHP
PHP中Session可能会引起并发问题
2015/06/26 PHP
详解PHP如何更好的利用PHPstorm的自动提示
2017/08/18 PHP
php传值和传引用的区别点总结
2019/11/19 PHP
php实现的简单多进程服务器类完整示例
2020/02/01 PHP
Chrome Form多次提交表单问题的解决方法
2011/05/09 Javascript
JS中图片缓冲loading技术的实例代码
2013/08/29 Javascript
深入了解Node.js中的一些特性
2014/09/25 Javascript
javascript日期处理函数,性能优化批处理
2015/09/06 Javascript
jQuery简单实现两级下拉菜单效果代码
2015/09/15 Javascript
关于cookie的初识和运用(js和jq)
2016/04/07 Javascript
JS函数的定义与调用方法推荐
2016/05/12 Javascript
AngularJs解决跨域问题案例详解(简单方法)
2016/05/19 Javascript
关于JavaScript限制字数的输入框的那些事
2016/08/14 Javascript
jQuery通过ajax方法获取json数据不执行success的原因及解决方法
2016/10/15 Javascript
input file上传 图片预览功能实例代码
2016/10/25 Javascript
javascript 删除数组元素和清空数组的简单方法
2017/02/24 Javascript
javascript、php关键字搜索函数的使用方法
2018/05/29 Javascript
Vue slot用法(小结)
2018/10/22 Javascript
JavaScript检测浏览器是否支持CSS变量代码实例
2020/04/03 Javascript
js实现简单抽奖功能
2020/11/24 Javascript
仅利用30行Python代码来展示X算法
2015/04/01 Python
Python实现计算文件夹下.h和.cpp文件的总行数
2015/04/23 Python
python+mysql实现学生信息查询系统
2019/02/21 Python
python游戏开发之视频转彩色字符动画
2019/04/26 Python
python实现弹跳小球
2019/05/13 Python
在Qt中正确的设置窗体的背景图片的几种方法总结
2019/06/19 Python
Fabletics官网:美国运动服饰品牌,由好莱坞女演员凯特·哈德森创立
2019/10/19 全球购物
开学典礼策划方案
2014/05/28 职场文书
护理实习生带教计划
2015/01/16 职场文书
死磕 java同步系列之synchronized解析
2021/06/28 Java/Android
python读取并查看npz/npy文件数据以及数据显示方法
2022/04/14 Python