django2.x使用JSONField


参考:
Django ORM中原生JSONField的使用方法
Django3.x和2.x JSONFiled使用

前言

使用JSONField在反序列化的时候有问题,jsonfield.JSONField会报错”不是有效的字符串”,rest_framework.fields.JSONField会忽略json字段导致序列化了个寂寞。

jsonfield.JSONFieldJSONField在数据库中存储都一样,都是json字段,使用赋值也是dict的形式。但前者用drf序列化出的数据(serializer.data)中该字段是字符串,后者是字典。

jsonfield模块

这里有个使用jsonfield.JSONField的解决办法,在将request.data给序列化器进行反序列化之前,对data里面的json字典数据用json.dumps()转字符串。

    def update(self, request, *args, **kwargs):
        data = request.data
        data["config"] = json.dumps(data["config"])
        instance = DataSyncConfig.objects.get(pk=DATA_SYNC_CONFIG_ID)
        serializer = self.get_serializer(instance, data=data)
        serializer.is_valid(raise_exception=True)
        self.perform_update(serializer)

        return Response(serializer.data)

但会产生另一个问题就是数据库存的是字符串而不是json了。

image

当然也有解决办法,重写to_representation()to_internal_value方法对序列化前后的数据做处理。
但是太麻烦啦,所以我们换成django_mysql提供的JSONField吧。。

django_mysql.JSONField

django3.1新增了models.JSONField,还支持很多JSONField的orm查询方法
但我们是2.x的版本,故需要第三方库的支持
1、requirements.txt中加入

django-mysql==3.9.0

2、install一下

pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple --trusted-host pypi.tuna.tsinghua.edu.cn

3、使用

from django_mysql.models import JSONField

    ...
    config = JSONField("配置信息", default=dict)
    ...

原创文章,作者:kepupublish,如若转载,请注明出处:https://blog.ytso.com/273324.html

(0)
上一篇 2022年7月10日
下一篇 2022年7月10日

相关推荐

发表回复

登录后才能评论