Django Rest Framework中嵌套关系的JSON序列化

Django Rest Framework (DRF) 中,处理嵌套关系的 JSON 序列化是一个常见需求。以下是如何实现嵌套关系序列化的详细说明,包括序列化器定义、模型关系以及常见用法。

1、问题背景

假设我们有以下两个模型:

复制代码
class Jobdtl(models.Model):
    jobdtl_id = models.IntegerField(primary_key=True)
    jobdtl_cmd = models.TextField(blank=True)
    jobdtl_envfile = models.TextField(blank=True)
    jobdtl_retnsn = models.SmallIntegerField(blank=True, null=True)
    jobdtl_allowadhoc = models.CharField(max_length=1, blank=True)
    jobdtl_waitop = models.CharField(max_length=1, blank=True)

    class Meta:
        managed = False
        db_table = 'jobdtl'

class Jobmst(models.Model):
    jobmst_id = models.IntegerField(primary_key=True)
    jobmst_prntid = models.IntegerField(blank=True, null=True)
    jobmst_active = models.CharField(max_length=1, blank=True)
    jobmst_evntoffset = models.SmallIntegerField(blank=True, null=True)
    jobmst_name = models.TextField(blank=True)
    jobmst_owner = models.IntegerField(blank=True, null=True)
    jobmst_crttm = models.DateTimeField()
    jobdtl_id = models.ForeignKey('Jobdtl', db_column='jobdtl_id', related_name='mstdtl', blank=True, null=True)
    jobmst_lstchgtm = models.DateTimeField(blank=True, null=True)
    def __unicode__(self):
        return self.jobmst_name   
    class Meta:
        managed = False
        db_table = 'jobmst'

我们希望能够将这两个模型的数据序列化成一个嵌套的JSON格式,类似于如下格式:

复制代码
{
  "jobmst": {
    "jobmst_id": 1,
    "jobmst_prntid": null,
    "jobmst_active": "Y",
    "jobmst_evntoffset": null,
    "jobmst_name": "Job 1",
    "jobmst_owner": 1001,
    "jobmst_crttm": "2023-03-08T16:33:19.439773Z",
    "jobdtl_id": 1,
    "jobmst_lstchgtm": null
  },
  "jobdtl": {
    "jobdtl_id": 1,
    "jobdtl_cmd": "echo Hello World",
    "jobdtl_envfile": null,
    "jobdtl_retnsn": 0,
    "jobdtl_allowadhoc": "Y",
    "jobdtl_waitop": "N"
  }
}

2、解决方案

2.1 编写序列化器

首先,我们需要为这两个模型编写序列化器,以便将模型数据转换为JSON格式。

python 复制代码
class JobmstSerializer(serializers.ModelSerializer):
    jobdtl_id = JobdtlSerializer()

    class Meta:
        model = Jobmst

class JobdtlSerializer(serializers.ModelSerializer):
    class Meta:
        model = Jobdtl

2.2 编写视图

接下来,我们需要编写一个视图来处理HTTP请求,并使用序列化器将模型数据序列化成JSON格式。

python 复制代码
class ResultsList(ListAPIView):
    def list(self, request, *args, **kwargs):
        jobmstquery = Jobmst.objects.using('Admiral').all()
        jobdtlquery = Jobdtl.objects.using('Admiral').all()

        results = list()
        entries = list(chain(jobmstquery, jobdtlquery)) # combine the two querysets
        for entry in entries:
            type = entry.__class__.__name__.lower() # 'jobmst', 'jobdtl'
            if isinstance(entry, Jobmst):
                serializer = JobmstSerializer(entry)
                dictionary = {'type': type, 'jobmst_data': serializer.data}
            if isinstance(entry, Jobdtl):
                serializer = JobdtlSerializer(entry)
                dictionary = {'type': type, 'jobdtl_data': serializer.data}
            results.append(dictionary)
        return Response(results)

2.3 配置URL路由

最后,我们需要在URL路由中配置视图,以便当用户访问特定URL时,能够调用相应的视图。

python 复制代码
urlpatterns = patterns('TidalDEV.views',
    url(r'^TidalDEV/$', 'ResultsList'),
    url(r'^TidalDEV/(?P<pk>[0-9]+)/$', 'ResultsList'),
)

2.4 测试结果

现在,我们可以通过访问URL来测试我们的API。例如,访问URL http://localhost/TidalDEV/,会返回所有Jobmst和Jobdtl模型数据的JSON序列化结果。访问URL http://localhost/TidalDEV/50244/,会返回Jobmst和Jobdtl模型数据的JSON序列化结果,其中Jobmst的jobmst_id为50244。

总结

通过以上步骤,我们实现了在Django Rest Framework中对嵌套关系的JSON序列化。这为我们提供了更加灵活的方式来处理复杂的数据结构,并将其转换为JSON格式。

这样可以高效处理复杂的嵌套关系,提升 API 的可用性和性能!

相关推荐
咸甜适中19 小时前
rust语言待办事项小实例完整代码(axum+sqlx+sqlite+自定义错误)
rust·sqlite·axum·sqlx
SuperEugene21 小时前
Vue3 配置驱动弹窗:JSON配置弹窗内容/按钮,避免重复开发弹窗|配置驱动开发实战篇
前端·javascript·vue.js·前端框架·json
万粉变现经纪人21 小时前
如何解决 pip install flash-attention 报错 需要 SM_80+(Ampere)架构 问题
python·架构·django·bug·virtualenv·pip·pygame
专注VB编程开发20年21 小时前
2000条25列数据导出到Sqlite只用40毫秒,ACCESS用时800-1300毫秒
数据库·sqlite·access
云和数据.ChenGuang1 天前
机器学习之方差和标准差计算
人工智能·python·机器学习·django·pygame·deepseek
开开心心就好1 天前
经典塔防游戏移植移动端随时畅玩
java·前端·科技·游戏·edge·django·pdf
五仁火烧1 天前
前端最常用的两种请求数据格式application/json 和 multipart/form-data 完全解析
前端·javascript·vue.js·json
吹个口哨写代码1 天前
h5/小程序直接读本地/在线的json文件数据
前端·小程序·json
DevOpenClub1 天前
文章抽取信息化 JSON API 接口
json
电商API&Tina2 天前
1688 拍立淘接口(item_search_img)测试与接入实战心得
java·大数据·前端·物联网·oracle·json