[Django] #32179: Add JSONObject Func

51 views
Skip to first unread message

Django

unread,
Nov 8, 2020, 2:47:24 AM11/8/20
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: | Owner: nobody
Chiorufarewerin |
Type: New | Status: new
feature |
Component: Database | Version: master
layer (models, ORM) | Keywords: json_object,
Severity: Normal | jsonb_build_object, JSONObject
Triage Stage: | Has patch: 0
Unreviewed |
Needs documentation: 0 | Needs tests: 0
Patch needs improvement: 0 | Easy pickings: 0
UI/UX: 0 |
-------------------------------------+-------------------------------------
So I currently use for build json object for postgres like:

{{{
Func(
Value('name'), 'authors__name',
Value('alias'), 'authors__alias',
function='jsonb_build_object'
)
}}}

I checked other dbs formats for this, and all of this have that
functional:
https://www.sqlite.org/json1.html#jobj
https://dev.mysql.com/doc/refman/8.0/en/json-creation-functions.html
#function_json-object
https://docs.oracle.com/en/database/oracle/oracle-
database/12.2/sqlrf/JSON_OBJECT.html

I use it for related objects, for example:

{{{
class Article(models.Model):
title = models.CharField(max_length=50)


class Product(models.Model):
article = models.ForeignKey(Article, related_name='products',
on_delete=models.CASCADE)
name = models.CharField(max_length=255)

Product.objects.annotate(
article_json=Func(
Value('title'), 'article__title',
function='JSONB_BUILD_OBJECT',
)
).values('name', 'article_json').first()
}}}

So, with JSONObject will be something like this:

{{{
Product.objects.annotate(
article_json=JSONObject(
title='article__title',
)
).values('name', 'article_json').first()
}}}

--
Ticket URL: <https://code.djangoproject.com/ticket/32179>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.

Django

unread,
Nov 8, 2020, 2:48:26 AM11/8/20
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: Chiorufarewerin | Owner:
| Chiorufarewerin
Type: New feature | Status: assigned
Component: Database layer | Version: master
(models, ORM) |
Severity: Normal | Resolution:
Keywords: json_object, | Triage Stage:
jsonb_build_object, JSONObject | Unreviewed
Has patch: 0 | Needs documentation: 0

Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------------+-------------------------------------
Changes (by Chiorufarewerin):

* owner: nobody => Chiorufarewerin
* status: new => assigned


--
Ticket URL: <https://code.djangoproject.com/ticket/32179#comment:1>

Django

unread,
Nov 8, 2020, 8:16:25 AM11/8/20
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: Chiorufarewerin | Owner:
| Chiorufarewerin
Type: New feature | Status: assigned
Component: Database layer | Version: master
(models, ORM) |
Severity: Normal | Resolution:
Keywords: json_object, | Triage Stage: Accepted
jsonb_build_object, JSONObject |
Has patch: 0 | Needs documentation: 0

Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------------+-------------------------------------
Changes (by Simon Charette):

* stage: Unreviewed => Accepted


--
Ticket URL: <https://code.djangoproject.com/ticket/32179#comment:2>

Django

unread,
Nov 8, 2020, 8:16:54 AM11/8/20
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: Chiorufarewerin | Owner:
| Chiorufarewerin
Type: New feature | Status: assigned
Component: Database layer | Version: master
(models, ORM) |
Severity: Normal | Resolution:
Keywords: json_object, | Triage Stage: Accepted
jsonb_build_object, JSONObject |
Has patch: 1 | Needs documentation: 0

Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------------+-------------------------------------
Changes (by Simon Charette):

* has_patch: 0 => 1


--
Ticket URL: <https://code.djangoproject.com/ticket/32179#comment:3>

Django

unread,
Nov 9, 2020, 4:18:42 AM11/9/20
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: Chiorufarewerin | Owner:
| Chiorufarewerin
Type: New feature | Status: assigned
Component: Database layer | Version: master
(models, ORM) |
Severity: Normal | Resolution:
Keywords: json_object, | Triage Stage: Accepted
jsonb_build_object, JSONObject |
Has patch: 1 | Needs documentation: 0
Needs tests: 0 | Patch needs improvement: 1

Easy pickings: 0 | UI/UX: 0
-------------------------------------+-------------------------------------
Changes (by Mariusz Felisiak):

* needs_better_patch: 0 => 1


--
Ticket URL: <https://code.djangoproject.com/ticket/32179#comment:4>

Django

unread,
Dec 2, 2020, 3:32:48 AM12/2/20
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: Chiorufarewerin | Owner:
| Chiorufarewerin
Type: New feature | Status: assigned
Component: Database layer | Version: master
(models, ORM) |
Severity: Normal | Resolution:
Keywords: json_object, | Triage Stage: Ready for
jsonb_build_object, JSONObject | checkin
Has patch: 1 | Needs documentation: 0

Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------------+-------------------------------------
Changes (by Mariusz Felisiak):

* needs_better_patch: 1 => 0
* stage: Accepted => Ready for checkin


--
Ticket URL: <https://code.djangoproject.com/ticket/32179#comment:5>

Django

unread,
Dec 2, 2020, 12:30:41 PM12/2/20
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: Chiorufarewerin | Owner:
| Chiorufarewerin
Type: New feature | Status: closed

Component: Database layer | Version: master
(models, ORM) |
Severity: Normal | Resolution: fixed

Keywords: json_object, | Triage Stage: Ready for
jsonb_build_object, JSONObject | checkin
Has patch: 1 | Needs documentation: 0

Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------------+-------------------------------------
Changes (by Mariusz Felisiak <felisiak.mariusz@…>):

* status: assigned => closed
* resolution: => fixed


Comment:

In [changeset:"48b4bae983a1f9a73624fe62ef5bd1130b0dba39" 48b4bae9]:
{{{
#!CommitTicketReference repository=""
revision="48b4bae983a1f9a73624fe62ef5bd1130b0dba39"
Fixed #32179 -- Added JSONObject database function.
}}}

--
Ticket URL: <https://code.djangoproject.com/ticket/32179#comment:6>

Django

unread,
Dec 16, 2024, 6:06:15 AM12/16/24
to django-...@googlegroups.com
#32179: Add JSONObject Func
-------------------------------------+-------------------------------------
Reporter: Chiorufarewerin | Owner:
| Chiorufarewerin
Type: New feature | Status: closed
Component: Database layer | Version: dev
(models, ORM) |
Severity: Normal | Resolution: fixed
Keywords: json_object, | Triage Stage: Ready for
jsonb_build_object, JSONObject | checkin
Has patch: 1 | Needs documentation: 0
Needs tests: 0 | Patch needs improvement: 0
Easy pickings: 0 | UI/UX: 0
-------------------------------------+-------------------------------------
Comment (by Sarah Boyce <42296566+sarahboyce@…>):

In [changeset:"d7d711c68cc070d9b6962f43f97ece097162adcc" d7d711c6]:
{{{#!CommitTicketReference repository=""
revision="d7d711c68cc070d9b6962f43f97ece097162adcc"
Refs #35718, Refs #32179 -- Moved JSONObject to
django.db.models.functions.json.
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/32179#comment:7>
Reply all
Reply to author
Forward
0 new messages