답변:
table1.objects.exclude(id__in=
table2.objects.filter(your_condition).values_list('id', flat=True))
제외 기능은 Not
요청 하는 연산자 처럼 작동 합니다. 이 속성 flat = True
은 table2
쿼리에를 value_list
한 수준 목록으로 반환하도록 지시 합니다. 그래서 ... 끝에 IDs
table2에서 목록을 얻습니다. 에서 조건을 정의하기 위해 사용자 table1
가 될 것이며 제외 기능에 의해 거부됩니다.
Objs=Tbl1.objects.filter(...); IDs=Objs.values_list('id', flat=True); Objs.delete(); Tbl2.objects.filter(id__in=IDs')
ID가 실제로 QuerySet 개체이기 때문에 작동하지 않았습니다. 원래 행을 삭제하면 더 이상 다른 쿼리와 함께 작동하지 않습니다. 이 솔루션은있다 Tbl2.objects.filter(id__in=list(IDs))
- 목록으로 바꿀
annotate()
(timeit는 0.00514069400014705 대 나에게 1.0497902309998608 준)
이 모델 :
class table1(models.Model):
field1 = models.CharField(max_length=10) # a dummy field
class table2(models.Model):
key_to_table1 = models.ForeignKey(table1)
다음을 사용하여 원하는 것을 얻어야합니다.
table1.objects.exclude(table2=some_param)
Django 쿼리에 대한 사용자 지정 조회를 작성할 수 있습니다.
로부터 문서 :
". 간단한 사용자 정의 조회와하자의 시작 우리는 사용자 정의 조회 작성합니다 NE 하는 반대 작동 정확한을 . Author.objects.filter (name__ne = '잭') 는 SQL로 변환됩니다 "author"."name" <> 'Jack'
"
from django.db.models import Lookup
class NotEqual(Lookup):
lookup_name = 'ne'
def as_sql(self, compiler, connection):
lhs, lhs_params = self.process_lhs(compiler, connection)
rhs, rhs_params = self.process_rhs(compiler, connection)
params = lhs_params + rhs_params
return '%s <> %s' % (lhs, rhs), params
[o1 for o1 in table1.objects.all() if o1.id not in [o2.id for o2 in table2.objects.filter(id=some_parm)]]
또는 더 나은
not_in_ids = [obj.id for obj in table2.objects.filter(id=some_parm)]
selected_objects = [obj for obj in table1.objects.iterator() if obj.id not in not_in_ids]