[英]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.