DRF框架中链表数据通过ModelSerializer深度查询方法汇总

Stella981
• 阅读 651

DRF框架中链表数据通过ModelSerializer深度查询方法汇总

一.准备测试和理解准备

创建类

class Test1(models.Model):
    id = models.IntegerField(primary_key=True)
    test_2_id= models.ForeignKey(to='Test2',on_delete='id') #这里有的创建失败了哈哈忘了会自动补全id

class Test2(models.Model):
    id = models.IntegerField(primary_key=True)
    name = models.CharField(max_length=60)

生成表单数据

Test1

id

test_2_id_id

1

1

2

2

Test2

id

name

1

名字1

2

名字2

二.深度查询通过Test1获得Test2的name而不是id

方法一

models.py

#对于test1添加方法
class Test1(models.Model):
    id = models.IntegerField(primary_key=True)
    test_2_id= models.ForeignKey(to='Test2',on_delete='id')
    @property
    def get_test2_name(self):
        return self.test_2_id.name

views.py

from rest_framework.serializers import ModelSerializer
from app.models import Test1
class Test_ser(ModelSerializer):
    class Meta:
        model = Test1  # 这里会把Test1面的所有名称空间存在的都进行导入
        fields = ('id','get_test2_name')

class Test(APIView):
    def get(self,request):
        test1_objs = Test1.objects.all()
        test1_ser = Test_ser(instance=test1_objs,many=True).data
        for a in test1_ser:
            print(a)
        return HttpResponse('ok')

方法二

views.py

from rest_framework.serializers import ModelSerializer
from app.models import Test1,Test2


class Test_2_ser(ModelSerializer):
    class Meta:
        model = Test2
        fields = '__all__'

class Test_ser(ModelSerializer):
    test_2_id = Test_2_ser()  #test_2_id为Test1与Test2关联的字段
    class Meta:
        model = Test1  
        fields = '__all__'

class Test(APIView):
    def get(self,request):
        test1_objs = Test1.objects.all()
        test1_ser = Test_ser(instance=test1_objs,many=True).data
        for a in test1_ser:
            print(a)
        return HttpResponse('ok')

方法三

#通过添加自定义字段
class Test_ser(ModelSerializer):
    test_2_name = SerializerMethodField() #自定义字段名称
    def get_test_2_name(self,model):  #这里方法名必须get_字段名称
        return model.test_2_id.name    #对于获取字段后的返回值
    class Meta:
        model = Test1  
        fields = '__all__'

class Test(APIView):
    def get(self,request):
        test1_objs = Test1.objects.all()
        test1_ser = Test_ser(instance=test1_objs,many=True).data
        for a in test1_ser:
            print(a)
        return HttpResponse('ok')

方法四

#通过添加自定义字段
class Test_ser(ModelSerializer):
    image_url=serializers.CharField(source='test_2_id.name') #test1中的test_2_id.name的内容
    class Meta:
        model = Test1  
        fields = '__all__'

class Test(APIView):
    def get(self,request):
        test1_objs = Test1.objects.all()
        test1_ser = Test_ser(instance=test1_objs,many=True,context={"request":request}).data
        for a in test1_ser:
            print(a)
        return HttpResponse('ok')
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
IDEA00 IDEA知识点汇总
一、从头搭建IDEA开发环境https://mp.weixin.qq.com/s/6jXHzkU8JfubhDsQJbwl8Q(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fmp.weixin.qq.com%2Fs%2F6jXHzkU8JfubhDsQJbwl8Q)1下
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(