一、PrimaryKeyRelatedField
1、可以定义PrimaryKeyRelatedField来获取关联表的外键值
2、如果通过父表获取从表数据,默认需要使用从表模型类名小写_set作为序列化器类中的关联字段名称
3、在序列化器类中定义PrimaryKeyRelatedField,当用postman获取列表数据时,会报错
报错信息说,要么指定read_only=True,或者指定get_queryset
当指定了read_only=True,表示我仅仅只做输出;一定要指定many=True,因为主表获取从表的数据获取的是多条数据;
当我指定了查询集,表示创建数据的时候给它指定一个queryset,接口id必须在我的这个查询集中
例如:当我的接口id在我的查询集中时:
serializers1.validated_data输出校验通过的数据,interfaces_set为该项目下所属的接口信息
当我的接口id不在我的查询集中:
此时校验不通过,原因是接口表中没有id为9的接口信息
综上所说:
5、如果指定了了read_only=True,那么该字段仅序列化输出
6、如果只指定了queryset参数(关联的查寻集对象),用于对参数进行校验
7、如果关联字段有多个值,那么必须添加many=True,一般父表获取从表数据时,关联字段需要指定
8、PrimaryKeyRelatedField获取的是从表的主键
二、StringRelatedField
将关联字段模型类中的__str__方法的返回值作为该字段的值
输出结果如下:
三、SlugRelatedField
1、使用SlugRelatedField字段,将关联模型类中的某个字段,作为该字段的值
2、如果指定了了read_only=True,那么该字段仅序列化输出
3、如果该字段需要进行反序列化输入,那么必须得指定queryset参数,同时关联字段必须有唯一约束
四、获取从表中的多个字段
1、如果想要通过父表(项目表)获取从表(接口表)得所有字段(id、name、tester),怎么做?
2)、自定义的序列化器类实际上也是Field的子类
3)、所以自定义的序列化器类可以作为另外一个序列化器中的字段来使用
4)、当我从表获取主表的数据时,用关联字段projects;以上3种都支持,注意:从表获取主表数据用不用many=True
获取数据
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/123647.html