djang模型类中BinaryField字段的序列化输出问题和外键问题

最近在项目开发时进行模型类设计时遇到了一些问题,在这里和大家分享以下

1.BinaryField字段的序列化输出问题

项目经理的需求是将多个不同数据库的查询结果信息存放到另一个关系型数据库(比如mysql1)中,那么多个数据库的查询信息的字段上,类型上都不相同,这导致我在存储数据库(mysql1)中无法顶一个各个字段,所以我就需要将查询结果当作一个大字段存入到一个字段中,但是因为查询结果的长度不可控,且后期数据可能大量扩展,所以如果按照CharFiled的方式存储就很不方便了,因为CharField需要定义长度,不利于扩展,不方便大数据使用,所以想到了file和binary,此处需求没必要使用file,所以最后使用BinaryFiled(看需求选择),那么在选择BinaryFiled之后,存储时需要进行数据的encode,因为BinaryFiled只能进行二进制存储,但是在输出时,因为我之前使用的序列化器继承了Modelserializer,导致输出字段直接按照存储方式序列化输出,没有进行deocde,所以乱码了,然后我就进行BinaryFiled自定义输出,但是一直不起作用,依然输出乱码,那么我分析了问题的根本在哪里

,于是我在取出数据后和序列化之前,以及序列化之后对比,发现问题就出现在序列化器上,我要做的就是在序列化器之前将数据进行decode,那么我查看serializers源代码时发现,当我们继承Modelserializer时,程序自动按照class Meta的元类中指定的模型类进行序列化和输出,自定义的输出对象根本不执行,所以需要进行父类

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django 中进行序列化时,如果要限制外键字段的返回字段,可以使用 `depth` 或者 `SerializerMethodField` 两种方式。 1. 使用 `depth` 属性 在定义 Serializer 时,可以通过设置 `depth` 属性来指定返回的外键字段的深度。例如,如果要限制返回 `Article` 模型中的 `author` 字段只返回 `id` 和 `username` 字段,则可以这样定义 Serializer: ```python class AuthorSerializer(serializers.ModelSerializer): class Meta: model = Author fields = ('id', 'username') class ArticleSerializer(serializers.ModelSerializer): author = AuthorSerializer(depth=1) class Meta: model = Article fields = ('id', 'title', 'content', 'author') ``` 这里将 `AuthorSerializer` 作为 `ArticleSerializer` 中 `author` 字段序列化器,并设置 `depth=1`,表示只返回 `Author` 模型中的一层字段。 2. 使用 `SerializerMethodField` 字段 另一种方法是使用 `SerializerMethodField` 字段,自定义返回的外键字段。例如,如果要限制返回 `Article` 模型中的 `author` 字段只返回 `id` 和 `username` 字段,则可以这样定义 Serializer: ```python class ArticleSerializer(serializers.ModelSerializer): author = serializers.SerializerMethodField() class Meta: model = Article fields = ('id', 'title', 'content', 'author') def get_author(self, obj): return {'id': obj.author.id, 'username': obj.author.username} ``` 这里重写了 `author` 字段序列化方法,返回一个字典,包含所需的字段

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值