mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #24751 -- Fixed HStoreField isnull lookup.
This commit is contained in:
@@ -78,7 +78,7 @@ class KeyTransform(Transform):
|
||||
|
||||
def as_sql(self, compiler, connection):
|
||||
lhs, params = compiler.compile(self.lhs)
|
||||
return "%s -> '%s'" % (lhs, self.key_name), params
|
||||
return "(%s -> '%s')" % (lhs, self.key_name), params
|
||||
|
||||
|
||||
class KeyTransformFactory(object):
|
||||
|
@@ -25,3 +25,5 @@ Bugfixes
|
||||
pointing to :class:`~django.db.models.UUIDField` and inheritance on models
|
||||
with ``UUIDField`` primary keys work correctly (:ticket:`24698`,
|
||||
:ticket:`24712`).
|
||||
|
||||
* Fixed ``isnull`` lookup for ``HStoreField`` (:ticket:`24751`).
|
||||
|
@@ -114,6 +114,17 @@ class TestQuerying(PostgresSQLTestCase):
|
||||
self.objs[:3]
|
||||
)
|
||||
|
||||
def test_key_isnull(self):
|
||||
obj = HStoreModel.objects.create(field={'a': None})
|
||||
self.assertSequenceEqual(
|
||||
HStoreModel.objects.filter(field__a__isnull=True),
|
||||
self.objs[2:5] + [obj]
|
||||
)
|
||||
self.assertSequenceEqual(
|
||||
HStoreModel.objects.filter(field__a__isnull=False),
|
||||
self.objs[:2]
|
||||
)
|
||||
|
||||
|
||||
class TestSerialization(PostgresSQLTestCase):
|
||||
test_data = '[{"fields": {"field": "{\\"a\\": \\"b\\"}"}, "model": "postgres_tests.hstoremodel", "pk": null}]'
|
||||
|
Reference in New Issue
Block a user