Serializer和ModelSerializer

简介: ModelSerializer 先使用ModelSerializer测试一下结果,例: # models.py ###### from django.db.models import Model, CharField, BooleanField, ForeignKey class TestM.

ModelSerializer

  • 先使用ModelSerializer测试一下结果,例:

    # models.py
    ######
    from django.db.models import Model, CharField, BooleanField, ForeignKey
    
    class TestModel(User):
        name = CharField(max_length=64, name='name')
    
    class TestModel(Model):
        status = BooleanField(default=False, name='status')
        user = ForeignKey(User, db_column="user_id", name='user', on_delete=CASCADE,
                                 related_name="user_test")
    
    ######
    
    # seriailzer.py
    ######
    from models import TestModel
    from rest_framework.serializers import ModelSerializer, IntegerField, Serializer
    from rest_framework.serializers import SerializerMethodField
    
    class TestSerializer(ModelSerializer):
        user = IntegerField(required=False)
        status = SerializerMethodField()
      
        class Meta:
            model = TestModel
            fields = ("id", "status", "uesr")
      
  • 把外键user设置为了非必填,但是现在去调用post接口就会发现user依然是必填的,会提示

    {
        "detail": "This field is required.",
        "sub_detail": {
            "user": [
                "This field is required."
            ]
        }
    }

Serializer

  • 再使用Serializer测试一下结果。
  • 代码就不在贴了,直接把serializer.py文件中的class TestSerializer(ModelSerializer):改为class TestSerializer(Serializer):就可以了
  • 这时就会发现再次调用接口就不会再出现问题了

区别

  • ModelSerializer类和Serializer类大致一样,不过添加了一些功能,可以更加便捷的去校验model中的数据.
  • ModelSerializer会基于 model 自动创建一些字段
  • ModelSerializer会自动生成一些验证,比如 unique_together 验证.
  • ModelSerializer包含简单的默认的 create()update().

参考链接:时光不写博客-Serializer和ModelSerializer

相关文章
|
3月前
|
缓存 NoSQL Redis
Redis雪崩
Redis雪崩
31 0
|
7月前
|
存储 NoSQL Redis
|
7月前
|
存储 缓存 NoSQL
|
8月前
|
运维 NoSQL Shell
redis-2
redis-2
50 0
|
8月前
|
存储 缓存 NoSQL
|
8月前
|
存储 消息中间件 缓存
了解redis
了解redis
49 0
|
存储 消息中间件 缓存
Redis总结(二)
redis 和 memcached 什么区别?为什么高并发下有时单线程的 redis 比多线程的memcached 效率要高?区别:1.mc 可缓存图片和视频。rd 支持除 k/v 更多的数据结构;2.rd 可以使用虚拟内存,rd 可持久化和 aof 灾难恢复,rd 通过主从支持数据备份;3.rd 可以做消息队列。原因:mc 多线程模型引入了缓存一致性和锁,加锁带来了性能损耗。redis 主从复制如何实现的?redis 的集群模式如何实现?redis 的 key 是如何寻址的?
89 0
|
存储 NoSQL Redis
什么是Redis?
什么是Redis?
90 2
什么是Redis?
|
存储 NoSQL Redis
Redis 为什么这么快?
Redis 为什么这么快?
105 0
Redis 为什么这么快?
|
存储 缓存 NoSQL
什么是 Redis?
Redis简介
132 0