简体   繁体   English

如何通过连接 django Rest 框架从其他表中获取数据

[英]How Get data with join django Rest framework from other table

I have two models first one is我有两个模型第一个是

class Event(models.Model):
    main_image = models.ImageField(upload_to='events/images', default="")
    event_name = models.CharField(max_length=100, default="")
    event_organizer = models.ForeignKey(
    Organizer, on_delete=models.CASCADE, limit_choices_to={'is_active': True})

and other one is另一个是

class additional_images(models.Model):
   # When a Event is deleted, upload models are also deleted
   event = models.ForeignKey(Event, on_delete=models.CASCADE)
   image = models.FileField(upload_to='events/images', null=True, blank=True, default="")

and serializer class is given by和序列化器 class 由下式给出

class eventSerializer(serializers.ModelSerializer):
    class Meta:
        model = Event
        fields = ['id', 'main_image', 'event_name', 'event_address', 'event_organizer']

my question is how i get additional_images with eventSerializer .我的问题是我如何使用eventSerializer获得additional_images

Thanks to Bear Brown .感谢熊布朗 his comment was helpful and I post it as a answer Update my additional_images model他的评论很有帮助,我将其发布为答案更新我的additional_images图像 model

class additional_images(models.Model):

    event = models.ForeignKey(Event, on_delete=models.CASCADE, 
                             related_name="additional_images",
                             related_query_name="additional_image",)
   image = models.FileField(upload_to='events/images', null=True, blank=True, default="")

And make serializer class for this并为此制作序列化器 class

class additionalImagesSerializer(serializers.ModelSerializer):
    class Meta:
        model = additional_images
        fields = ['image']

And in eventSerializer class并在eventSerializer

class eventSerializer(serializers.ModelSerializer):
    additional_images = additionalImagesSerializer(many=True, read_only=True)
    class Meta:
        model = Event
        fields = ['additional_images', 'id', 'main_image', 'event_name', 
                  'event_address',  'event_organizer']

That's work Perfectly!这是完美的工作!

You can read about ForeignKey and how to access the relation between them in the documentation.您可以在文档中阅读有关ForeignKey以及如何访问它们之间的关系的信息。

But, you can do something like this:但是,您可以执行以下操作:

1) (Optional) specify related_name: 1) (可选)指定相关名称:

class additional_images(models.Model):
   # When a Event is deleted, upload models are also deleted
   event = models.ForeignKey(Event, on_delete=models.CASCADE, related_name="images")

2) You can now access it with event.images . 2)您现在可以使用event.images访问它。 So you can use that in your serializer:所以你可以在你的序列化器中使用它:

class eventSerializer(serializers.ModelSerializer):
    class Meta:
        model = Event
        fields = ['id', 'main_image', 'event_name', 'event_address', 'event_organizer', 'images']

Now you will get images as a list of image ids.现在您将获得图像作为图像 ID 列表。 If you have a image serialier, you can specify a nested serializer in your event serializer.如果您有图像序列化器,则可以在事件序列化器中指定嵌套序列化器。

Code review comment: You have 3 classes, and each of them has different naming convention.代码审查评论:你有 3 个类,每个类都有不同的命名约定。 Stick to one, preferably -> EventSerializer .坚持一个,最好 -> EventSerializer

class eventSerializer(serializers.ModelSerializer):
    image = serializers.CharField(source='additional_images.get_image_url', read_only=True)
    additional_images = serializers.PrimaryKeyRelatedField(queryset=additional_images.objects.all())
    class Meta:
    model = Event
    fields = ['id','main_image', 'event_address',  'event_organizer', 'additional_images', 'image']

and define a get image url method in your models并在您的模型中定义获取图像 url 方法

class additional_images(models.Model):
   .........
   def get_image_url(self):
       returen "%s,%s" %(settings.MEDIA_URL, self.image)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM