https://www.django-rest-framework.org/api-guide/relations/

在编程中核心的就是数据结构。

关系字段用来表示model之间的关系,比如外键,m2m,o2o,还有反转关系,自定义关系-GenericForeignKey

关系字段申明在relations.py中,在使用的时候,可以在自己的序列化类中使用serializers.<FieldName>来引用。

使用ModelSerializers类的时候,会自动生成序列化字段和关系,我们可以检查这些自动生成的字段,然后来决定如何自定义关系样式。

(venv) E:\Python\dj_test>python manage.py shell
>>> from xxx.serializers import ClothesSerializer
>>> serializer = ClothesSerializer()
>>> print(repr(serializer))
ClothesSerializer():
url = HyperlinkedIdentityField(view_name='clothes-detail')
id = IntegerField(label='ID', read_only=True)
color = SlugRelatedField(queryset=<QuerySet [<Colors: instance:yellow>, <Colors: instance:red>]>, slug_field='colors_cn')
desc = CharField(max_length=64)
#使用shell,导入序列化类,然后实例化,然后使用repr函数打印这个实例的对象关系

  

API Reference

为了解释多个类型的关系字段,这里使用几个例子。我们的模型将用于音乐专辑Album,以及每张专辑中列出的曲目Track。

StringRelatedField

在这个案例中,可以查看使用yellow颜色作为外键的clothes有哪些,这个clothes字段在这里是read only。

它的作用是得到关联表model.__str__方法的返回字段。因为对应的子表是to-many关系,所以要加上many=True

class ColorsSerializer(serializers.ModelSerializer):
clothes = serializers.StringRelatedField(many=True) class Meta:
model = Colors
fields = ('url', 'id', 'colors', 'clothes')
--->
{
"url": "http://127.0.0.1:8002/colors/1/",
"id": 1,
"colors": "yellow",
"clothes": [
"内衣一号",
"内衣二号"
]
}

Arguments:

  • many - If applied to a to-many relationship, you should set this argument to True

  

PrimaryKeyRelatedField

它的作用是得到关联表的主键。

class ColorsSerializer(serializers.ModelSerializer):
clothes = serializers.PrimaryKeyRelatedField(queryset=Colors.objects.all(),many=True) class Meta:
model = Colors
fields = ('url', 'id', 'colors', 'clothes')
--->
{
"url": "http://127.0.0.1:8002/colors/1/",
"id": 1,
"colors": "yellow",
"clothes": [
1,
2
]
}

  

By default this field is read-write, although you can change this behavior using the read_only flag.

Arguments:

  • queryset - The queryset used for model instance lookups when validating the field input. Relationships must either set a queryset explicitly, or set read_only=True.
  • many - If applied to a to-many relationship, you should set this argument to True.
  • allow_null - If set to True, the field will accept values of None or the empty string for nullable relationships. Defaults to False.
  • pk_field - Set to a field to control serialization/deserialization of the primary key's value. For example, pk_field=UUIDField(format='hex') would serialize a UUID primary key into its compact hex representation.

HyperlinkedRelatedField

它的作用是得到关联表的url

class ColorsSerializer(serializers.ModelSerializer):
clothes = serializers.HyperlinkedRelatedField(queryset=Colors.objects.all(),many=True,view_name='clothes-detail') class Meta:
model = Colors
fields = ('url', 'id', 'colors', 'clothes')
--->
{
"url": "http://127.0.0.1:8002/colors/1/",
"id": 1,
"colors": "yellow",
"clothes": [
"http://127.0.0.1:8002/clothes/1/",
"http://127.0.0.1:8002/clothes/2/"
]
}

  

By default this field is read-write, although you can change this behavior using the read_only flag.


Note: This field is designed for objects that map to a URL that accepts a single URL keyword argument, as set using the lookup_field and lookup_url_kwarg arguments.

This is suitable for URLs that contain a single primary key or slug argument as part of the URL.

If you require more complex hyperlinked representation you'll need to customize the field, as described in the custom hyperlinked fields section, below.


Arguments:

  • view_name - The view name that should be used as the target of the relationship. If you're using the standard router classes this will be a string with the format <modelname>-detailrequired.
  • queryset - The queryset used for model instance lookups when validating the field input. Relationships must either set a queryset explicitly, or set read_only=True.
  • many - If applied to a to-many relationship, you should set this argument to True.
  • allow_null - If set to True, the field will accept values of None or the empty string for nullable relationships. Defaults to False.
  • lookup_field - The field on the target that should be used for the lookup. Should correspond to a URL keyword argument on the referenced view. Default is 'pk'.
  • lookup_url_kwarg - The name of the keyword argument defined in the URL conf that corresponds to the lookup field. Defaults to using the same value as lookup_field.
  • format - If using format suffixes, hyperlinked fields will use the same format suffix for the target unless overridden by using the format argument.

SlugRelatedField

它的作用是得到关联表的具体某个字段

# Clothes的color是外键,默认情况下,color字段会对应母表的主键,id。
# 使用SlugRelatedField可以指向外键,slug_field表示获取哪个字段返回给color
# 这里color这个属性就被重写了
class ClothesSerializer(serializers.ModelSerializer):
color = serializers.SlugRelatedField(queryset=Colors.objects.all(), slug_field='colors')
class Meta:
model = Clothes
fields = ('url', 'id', 'color', 'desc')
--->
{
"url": "http://127.0.0.1:8002/clothes/5/",
"id": 5,
"color": "red",
"desc": "袜子三号"
}

 

By default this field is read-write, although you can change this behavior using the read_only flag.

When using SlugRelatedField as a read-write field, you will normally want to ensure that the slug field corresponds to a model field with unique=True.

Arguments:

  • slug_field - The field on the target that should be used to represent it. This should be a field that uniquely identifies any given instance. For example, usernamerequired
  • queryset - The queryset used for model instance lookups when validating the field input. Relationships must either set a queryset explicitly, or set read_only=True.
  • many - If applied to a to-many relationship, you should set this argument to True.
  • allow_null - If set to True, the field will accept values of None or the empty string for nullable relationships. Defaults to False.

HyperlinkedIdentityField

和HyperlinkedModelSerializer上的url字段一个作用

 

Nested relationships

class ColorsSerializer(serializers.ModelSerializer):
# 序列化嵌套
clothes = ClothesSerializer(many=True, read_only=True) class Meta:
model = Colors
fields = ('url', 'id', 'colors', 'clothes')
--->
{
"url": "http://127.0.0.1:8002/colors/1/",
"id": 1,
"colors": "yellow",
"clothes": [
{
"url": "http://127.0.0.1:8002/clothes/1/",
"id": 1,
"color": "yellow",
"desc": "内衣三号"
},
{
"url": "http://127.0.0.1:8002/clothes/2/",
"id": 2,
"color": "yellow",
"desc": "内衣二号"
}
]
}
#被嵌套的关联表,整个出现在母表的字段中

  

Writable nested serializers

默认情况下,嵌套序列化程序是只读的。如果要支持对嵌套序列化程序字段的写操作,则需要创建create()和/或update()方法,以便明确指定应如何保存子关系。

class ColorsSerializer(serializers.ModelSerializer):
# 序列化嵌套
clothes = ClothesSerializer(many=True) class Meta:
model = Colors
fields = ('url', 'id', 'colors', 'clothes') def create(self, validated_data):
clothes_data = validated_data.pop('clothes') #先把clothes字段弹出来
colors = Colors.objects.create(**validated_data) #然后colors实例落表
for clothe_data in clothes_data: #clothes_data是多个实例
Clothes.objects.create(color=colors,**clothe_data) #把每个clothe实例落表,其中外键color指向color实例
return colors

  

DRF教程10-关系字段的更多相关文章

  1. 黑马lavarel教程---10、lavarel模型关联

    黑马lavarel教程---10.lavarel模型关联 一.总结 一句话总结: 1.模型关联比较方便,一次定义,后面都可以使用 2.关联关系 使用动态属性进行调用 1.一对多,多对多实例? 一对多: ...

  2. 无废话ExtJs 入门教程九[数字字段:NumberField、隐藏字段Hidden、日期字段:DataFiedl]

    无废话ExtJs 入门教程九[数字字段:NumberField.隐藏字段Hidden.日期字段:DataFiedl] extjs技术交流,欢迎加群(201926085) 继上第六节内容,我们在表单里加 ...

  3. 【译】ASP.NET MVC 5 教程 - 10:添加验证

    原文:[译]ASP.NET MVC 5 教程 - 10:添加验证 在本节中,我们将为Movie模型添加验证逻辑,并确认验证规则在用户试图使用程序创建和编辑电影时有效. DRY 原则 ASP.NET M ...

  4. Linux pwn入门教程(10)——针对函数重定位流程的几种攻击

    作者:Tangerine@SAINTSEC 本系列的最后一篇 感谢各位看客的支持 感谢原作者的付出一直以来都有读者向笔者咨询教程系列问题,奈何该系列并非笔者所写[笔者仅为代发]且笔者功底薄弱,故无法解 ...

  5. [译]Vulkan教程(10)交换链

    [译]Vulkan教程(10)交换链 Vulkan does not have the concept of a "default framebuffer", hence it r ...

  6. Django框架之第六篇(模型层)--单表查询和必知必会13条、单表查询之双下划线、Django ORM常用字段和参数、关系字段

    单表查询 补充一个知识点:在models.py建表是 create_time = models.DateField() 关键字参数: 1.auto_now:每次操作数据,都会自动刷新当前操作的时间 2 ...

  7. python 之 Django框架(ORM常用字段和字段参数、关系字段和和字段参数)

    12.324 Django ORM常用字段 .id = models.AutoField(primary_key=True):int自增列,必须填入参数 primary_key=True.当model ...

  8. Directx11教程(10) 画一个简易坐标轴

    原文:Directx11教程(10) 画一个简易坐标轴       本篇教程中,我们将在三维场景中,画一个简易的坐标轴,分别用红.绿.蓝三种颜色表示x,y,z轴的正向坐标轴. 为此,我们要先建立一个A ...

  9. 06 ORM常用字段 关系字段 数据库优化查询

    一.Django ORM 常用字段和参数 1.常用字段 models中所有的字段类型其实本质就那几种,整形varchar什么的,都没有实际的约束作用,虽然在models中没有任何限制作用,但是还是要分 ...

随机推荐

  1. java并发初探ReentrantWriteReadLock

    java并发初探ReentrantWriteReadLock ReenWriteReadLock类的优秀博客 ReentrantReadWriteLock读写锁详解 Java多线程系列--" ...

  2. Duilib自定义控件

    新版博客已经搭建好了,有问题请访问 htt://www.crazydebug.com 在公司二期项目中为了将谷歌内核嵌入到duilib中,采用了自定义duilib控件的方法,由于也是第一次用duili ...

  3. 关于AJAX跨域和原生AJAX CORS跨域解决

    项目需求要在别人的域名下调用自己的接口,因为浏览器的同源策略是不允许不同域名下之间的信息交换,那就意味着要跨域处理 参考博客 :https://blog.csdn.net/Ulricalin/arti ...

  4. eclipse不能启动,An internal error occurred during: "reload maven project".

    An internal error occurred during: "reload maven project". 这个错误是因为项目已经关闭,导致 导致此问题的原因是Sprin ...

  5. django的404,500错误自定义页面的配置

    django404,500错误自定义页面: 1.设置settings文件 DEBUG = False ALLOWED_HOSTS = ['127.0.0.1', 'localhost']或者ALLOW ...

  6. 如何配置vsftpd

    1   安装vsftpd组件 安装完后,有/etc/vsftpd/vsftpd.conf 文件,是vsftp的配置文件. [root@bogon ~]# yum -y install vsftpd 2 ...

  7. NPOI,导出Execl,压缩文件zip,发送Email

    private void SendEmail(string emailAddress, string companyName,string proxy, string officer, DataTab ...

  8. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 按钮:禁用状态

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  9. js 对象补充

    js 对象 普通对象与对象简写 js 没有字典类型,只有对象类型,对象可以完全替代字典来使用 js 中对象的属性名,都采用字符串类型,所以就可以省略字符串的引号标识 对象中属性值为函数时,称之为方法, ...

  10. CentOS7 环境下 在Hadoop集群安装Hive

    1.下载Hive的tar.gz包:http://mirror.bit.edu.cn/apache/hive/ 2.放入CentOS 7 系统中并解压:tar -zxvf apache-hive-2.3 ...