[https://docs.djangoproject.com/en/2.2/ref/contrib/postgres/fields/#django.contrib.postgres.fields.JSONField
The documentation] states that the {{{JSONField}}} uses internally a
PostgreSQL {{{jsonb}}} field, but I wonder if normal {{{json}}} fields
could also be detected as a {{{JSONField}}}, as they can perfectly work
for unmanaged models.
I'm happy to do a patch for this if it's considered necessary, adding an
additional key to the ones provided by the {{{contrib.postgres}}} module
inside the
[https://github.com/django/django/blob/2.2/django/contrib/postgres/apps.py#L49
data_types_reverse dict] with the following information:
{{{
114: 'django.contrib.postgres.fields.JSONField',
}}}
And the documentation and tests considered being necessary.
The id 114 is the OID of the {{{json}}} data type in PostgreSQL, at least
in its 11.1 version. You can check this by executing the following query:
{{{#!sql
SELECT oid, typname
FROM pg_catalog.pg_type
WHERE typname='json';
}}}
Also happy to check other database versions if needed.
--
Ticket URL: <https://code.djangoproject.com/ticket/30476>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
Old description:
> Right now, the {{{inspectdb}}} command, when the
> {{{django.contrib.postgres}}} app is added to {{{INSTALLED_APPS}}} in the
> settings, is able to detect {{{jsonb}}} fields and generate a model with
> the right {{{django.contrib.postgres.fields.JSONField}}}, but that's not
> the case for simple {{json}} fields.
>
> [https://docs.djangoproject.com/en/2.2/ref/contrib/postgres/fields/#django.contrib.postgres.fields.JSONField
> The documentation] states that the {{{JSONField}}} uses internally a
> PostgreSQL {{{jsonb}}} field, but I wonder if normal {{{json}}} fields
> could also be detected as a {{{JSONField}}}, as they can perfectly work
> for unmanaged models.
>
> I'm happy to do a patch for this if it's considered necessary, adding an
> additional key to the ones provided by the {{{contrib.postgres}}} module
> inside the
> [https://github.com/django/django/blob/2.2/django/contrib/postgres/apps.py#L49
> data_types_reverse dict] with the following information:
>
> {{{
> 114: 'django.contrib.postgres.fields.JSONField',
> }}}
>
> And the documentation and tests considered being necessary.
>
> The id 114 is the OID of the {{{json}}} data type in PostgreSQL, at least
> in its 11.1 version. You can check this by executing the following query:
>
> {{{#!sql
> SELECT oid, typname
> FROM pg_catalog.pg_type
> WHERE typname='json';
> }}}
>
> Also happy to check other database versions if needed.
New description:
{{{
114: 'django.contrib.postgres.fields.JSONField',
}}}
--
--
Ticket URL: <https://code.djangoproject.com/ticket/30476#comment:1>
Comment (by Simon Charette):
There's enough significant differences between `json` and `jsonb` types
which makes me believe this is not a good idea.
For example, [https://www.postgresql.org/docs/9.4/datatype-json.html
containment operators it not supported] on `json` columns while they are
on `jsonb` ones which breaks the `__contains`
[https://docs.djangoproject.com/en/2.2/ref/contrib/postgres/fields/#std
:fieldlookup-hstorefield.contains operator].
--
Ticket URL: <https://code.djangoproject.com/ticket/30476#comment:2>
* status: new => closed
* version: 2.2 => master
* resolution: => wontfix
Comment:
Thanks for the report, however "json" data type would not be fully
functional (especially in querying and indexing).
--
Ticket URL: <https://code.djangoproject.com/ticket/30476#comment:3>
Comment (by Adam (Chainz) Johnson):
Also worth bearing in mind is that there's a GSoC project underway to
create a cross-DB JSONField, which ultimately inspectdb should probably
point to
https://summerofcode.withgoogle.com/organizations/5465143218012160/#projects
--
Ticket URL: <https://code.djangoproject.com/ticket/30476#comment:4>