Python-Django 设置默认查询

场景描述

1,表A 和表B 是一对多
2,路由是由TableViewSet进来
3,(需求)查看表A的某一个详情时,再查询表B的时候默认过滤某个字段,此处以del_flag为例

为方便理解下面简单列出表关系和字段

Model类

class TableA(BaseModel):
    """
    表A
    """
    title = models.CharField(max_length=255, help_text="标题", default="", blank=True)
    no = models.CharField(max_length=255, help_text="编号", unique=True, default=uuid.uuid4, blank=True)
   
    is_read = models.IntegerField(help_text="是否已读",default=0)

    class Meta:
        verbose_name = verbose_name_plural = '表A'
        db_table = 'tableA'
class TableB(BaseModel):
    """
    表B
    """
    amount = models.DecimalField(help_text="申请金额", max_digits=18, decimal_places=2, default=0.0)
    remarks = models.CharField(help_text="备注", max_length=255, default="", blank=True)
    tablea= models.ForeignKey(TableA, help_text="事项", on_delete=models.PROTECT, default=2,
                               related_name="tableA")

    class Meta:
        verbose_name = verbose_name_plural = '表B'
        db_table = 'tableB'

序列化器(Serializers)

class TableASerializer(TableAListSerializer):
    no = UUIDBlankCharField(validators=[
        UniqueValidator(queryset=TableA.objects.all(), message='该编号已存在')])
    tableb= TableBSerializer(many=True, help_text='XXXX', required=False)
   
    remark = serializers.CharField(help_text="XXX", required=False, default=None,
                                   write_only=True)
    is_read = serializers.IntegerField(help_text="是否已读",required=False)

    @atomic
    def create(self, validated_data):
		XXXXXXXXXXXXX
        instance.save()
        return instance
    class Meta:
        model = TableA
        fields = (
            "title",
            "no",
            "tableb",
            "is_read"
        )
        
 class TableBSerializer(ChildrenModelSerializer):
    class Meta:
        model = TableB
        fields = (
            "amount",
            "remarks",
            "del_flag"
        )
        
 

方法

需要了解 Django的ListSerializer的to_representation方法,个人理解相当于java的构造方法。可以在你反序列化的时候为所欲为
修改后的序列化器

class DelFlagSerializer(serializers.ListSerializer):
    def to_representation(self, data):
        data = data.filter(del_flag=0)
        return super(DelFlagSerializer, self).to_representation(data)
class TableASerializer(TableAListSerializer):
    no = UUIDBlankCharField(validators=[
        UniqueValidator(queryset=TableA.objects.all(), message='该编号已存在')])
    tableb= TableBSerializer(many=True, help_text='XXXX', required=False)
   
    remark = serializers.CharField(help_text="XXX", required=False, default=None,
                                   write_only=True)
    is_read = serializers.IntegerField(help_text="是否已读",required=False)

    @atomic
    def create(self, validated_data):
		XXXXXXXXXXXXX
        instance.save()
        return instance
    class Meta:
        model = TableA
        fields = (
            "title",
            "no",
            "tableb",
            "is_read"
        )
        
 class TableBSerializer(ChildrenModelSerializer):
    class Meta:
        model = TableB
        fields = (
            "amount",
            "remarks",
            "del_flag"
        )
        list_serializer_class = DelFlagSerializer
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值