我们如何在 django-hstore 中查询嵌套字典?

How do we query nested dictionary in django-hstore?

我把这个存储在我的 serializedDictionaryField:

data = {
    'k1': 'v1',
    'k2': 'v2',
    'k3': {'nested_k': 'nested_v'}
}

是否可以根据嵌套字典的值进行过滤?像

Model.objects.filter(data__contains={'nested_k': 'nested_v'})

HStoreField 只是将字符串映射到字符串,不支持嵌套结构,您可以使用 JSONField,它是 Django 1.9+ 和 posgres 9.4+ 中的内置 Posgres 字段。

models.py:

from django.db import models
from django.contrib.postgres.fields.jsonb import JSONField
class MyModel(models.Model):
    ...
    data = JSONField(blank=True, null=True, default=dict)

views.py:

MyModel.objects.filter(data__k3__contains={'nested_k': 'nested_v'})