我有一个模型X
,其中包含自定义json data
,可能有也可能没有这些密钥:key1
,key2
,key3
。
我需要一种方法来使用key1
过滤所有实例。
我试过这样做:
queryset = X.objects.all()
queryset = queryset.annotate(
has_key1=(
Case(
When(~Q(data__key1__in=[None, '']), then=True),
default=False,
output_field=models.BooleanField())
)
)
但是queryset.filter(has_key1=True)
没有返回任何内容,但是有一些记录有key1。
直接过滤:queryset.filter(data__key1__in=[1])
工作正常。
有解决方案吗?谢谢。
答案 0 :(得分:5)
您可以使用以下方法排除所有NULL值和空字符串:
queryset = queryset.exclude(data__key1__isnull=True).exclude(data__key1__exact='')
答案 1 :(得分:5)
您可以在JSONField上使用has_key
。
JSONField和HStoreField共享此查找 - docs。
X.objects.filter(data__has_key='key_1')
这是一个基于我的项目的示例,我在FilterSet(django_filters.rest_framework)中的JSONField上使用has_key
来实现按键过滤(如果key不存在则返回0结果):
filters.py:
class XFilter(FilterSet):
data_search_by_key = django_filters.CharFilter(method='filter_data_key',
help_text='Search by key')
def filter_data_key(self, qs, name, value):
qs = X.objects.filter(data__has_key=value)
return qs