如何在DJANGO中合并多个查询集

如何在DJANGO中合并多个查询集,第1张

概述参见英文答案 > How to combine 2 or more querysets in a Django view?                                    10个 我必须在下面的单个列表中合并查询集: result_list_1 = Col.objects.defer("tags").filter(producer__username__icontains=c @H_404_4@ 参见英文答案 > How to combine 2 or more querysets in a Django view?                                    10个
我必须在下面的单个列表中合并查询集:

result_List_1 = Col.objects.defer("Tags").filter(producer__username__icontains=crit) result_List_2 = Col.objects.defer("Tags").filter(name__icontains=crit)result_List_3 = Col.objects.defer("Tags").filter(description__icontains=crit)result_List_4 = Col.objects.filter(Tags__name__icontains=crit)...

每个result_List都包含项目,这些项目具有唯一的数字ID,可用于确保没有重复项.

我不能用|同时查询DB或Q对象.

如何将结果集合并到一个列表中?

@H_404_4@解决方法 如何对itertools.chain稍作修改,以确保您不会遭遇欺骗:

def unique_chain(*iterables):    kNown_IDs = set()    for it in iterables:        for element in it:            if element.ID not in kNown_IDs:                kNown_IDs.add(element.ID)                yIEld element

有了它,您可以创建组合列表:

combined_List = List(unique_chain(result_List_1,result_List_2,... ))
@H_404_4@ @H_404_4@ @H_404_4@ @H_404_4@ 总结

以上是内存溢出为你收集整理的如何在DJANGO中合并多个查询集全部内容,希望文章能够帮你解决如何在DJANGO中合并多个查询集所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1193116.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存