后端不支持Django qs1.difference(qs2,qs3) [英] Django qs1.difference(qs2, qs3) not supported by backend

查看:233
本文介绍了后端不支持Django qs1.difference(qs2,qs3)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要从远程数据库中检查一个表并更新数据库中的另一个表。这些模型具有相同的字段,但使用差值方法检查将返回错误:

I need to check a table from a remote db and update another table in my db. The models have same fields but checking with difference method will return an error:


qs1从一个PostgreSQL数据库中获取数据

qs1 get the data from one postgresql db

qs2从一个mysql数据库获取数据

qs2 get the data from one mysql db



qs1 = (Local.objects
            .values_list('ref')
)
qs2 = (Remote.objects
            .filter()
            .values_list('ref'))

>>> qs1.difference(qs1, qs2)




DatabaseError:不支持交集此数据库后端。

DatabaseError: intersection not supported on this database backend.


推荐答案

check = Qs1.objects.all()
prg=[]
[prg.append(x.ref) for x in check]
difference = (Qs2.objects
        .exclude(ref__in=prg)
        .values()
)

也许不是很优雅,但是才行。

Maybe it's not elegant, but it just works.

这篇关于后端不支持Django qs1.difference(qs2,qs3)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆