加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

django 如何找到两个查询集(querySet)的并集?

发布时间:2020-12-15 17:14:19 所属栏目:大数据 来源:网络整理
导读:我有一个带有两个自定义管理器方法的Django模型。 每个对象都会根据对象的不同属性返回模型对象的不同子集。 有没有什么方法可以获取一个查询集,或者只是一个对象列表,那就是每个管理器方法返回的查询集的并集? 解决代码如下: records?=?query1?|?query2

我有一个带有两个自定义管理器方法的Django模型。 每个对象都会根据对象的不同属性返回模型对象的不同子集。

有没有什么方法可以获取一个查询集,或者只是一个对象列表,那就是每个管理器方法返回的查询集的并集?

解决代码如下:

records?=?query1?|?query2

如果不想拥有重复数据,这就需要增加一个方法:distinct()

records?=?(query1?|?query2).distinct()

django版本在1.11以后支持union方法

q?=?query1.union(query2)?#?q将包含query1?+?query2的所有唯一记录
q?=?query1.union(query2,?all=True)?#?q将包含query1?+?query2的所有记录(包括重复数据)
q?=?query1.union(query2,query3)?#?多个集合求并集


(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读