Django-REST框架序列化多个表关系

2024-10-01 07:30:19 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在为一个网站创建一个API,其中我有一个包含书籍的表,另一个带有Hashtags(基本上是一个Hashtags的目录,例如“#traveling”)和一个中间表来建立书籍和Hashtags之间的多对多关系。我的模型是:

# models.py
class Books(models.Model):
    id_books = models.AutoField(primary_key=True)
    title = models.CharField(max_length=150)

class Hashtags(models.Model):
    id_hashtags = models.AutoField(primary_key=True)
    hashtag = models.CharField(max_length=150)

class Books_Hashtags(models.Model):
    id_books_hashtags = models.AutoField(primary_key=True)
    id_books = models.ForeignKey(Books, on_delete=models.CASCADE)
    id_hashtags = models.ForeignKey(Hashtags, on_delete=models.CASCADE)
    class Meta:
        unique_together = ("id_books", "id_hashtags")

我希望有一个API可以提供这样的输出:

^{pr2}$

为此,我使用DRF对上面的模型进行了序列化,下面是我在网上找到的一些示例:

#serializers.py
from rest_framework import serializers
from app.models import Books, Books_Hashtags, Hashtags

class HashtagsSerializer(serializers.ModelSerializer):
    hashtags = serializers.CharField()
    class Meta:
        model = Hashtags
        fields = ('hashtag',)

class Books_HashtagsSerializer(serializers.ModelSerializer):
    id_hashtag = HashtagsSerializer(many=True, read_only=True)
    class Meta:
        model = Books_Hashtags
        fields = ('id_hashtags',)

class BooksSerializer(serializers.ModelSerializer):
    id_books = serializers.IntegerField()
    id_books_hashtags = Books_HashtagsSerializer(many=True, read_only=True)
    title = serializers.CharField()

    class Meta:
        model = Books
        fields = ('id_books', 'title', 'id_books_hashtags',)

我的观点如下:

#views.py
from ntgBackend.models import Books
from rest_framework import viewsets
from api.serializers import BooksSerializer

class BooksViewSet(viewsets.ModelViewSet):
    serializer_class = BooksSerializer
    queryset = Books.objects.all()

到目前为止,我已经成功地从API获得了以下输出:

[
    {
        "id_books": 1,
        "title": "The Hobbit",
    }
]

但是没有关于标签的信息,我知道它们存在于数据库中。 我在MySQL数据库和Django 2.0.2中使用drf3.8.2。 请帮忙!在


Tags: fromimportidtruetitlemodelsbooksmeta
1条回答
网友
1楼 · 发布于 2024-10-01 07:30:19

我也遇到了同样的问题,通过一些研究得出了以下结论:

在模型.py只需修改Book模型,使其包含一个ManyToManyField和一个使用Books\u Hashtagas作为中间表的Hashtagas。另外,一定要在第一本书之前声明你的Hashtag模型以供参考

# models.py
class Books(models.Model):
    id_books = models.AutoField(primary_key=True)
    title = models.CharField(max_length=150)
    hashtags = models.ManyToManyField(Hashtags, related_name='hashTg', through="Books_Hashtags"

在序列化程序文件中,确保添加depth=1以获得所需的内容,否则只能获得hashtag id(这仅适用于ListAPI)

^{pr2}$

在视图中,我使用泛型,因为它们解决了我的大部分需求:

#views.py
from ntgBackend.models import Books
from rest_framework import generics
from api.serializers import BooksSerializer

class BooksViewSet(generics.ListCreateAPIView):
    serializer_class = BooksSerializer
    queryset = Books.objects.all()

我对这件事很陌生,希望能有所帮助。除了Django(2.0.4),我使用的版本与您几乎相同。在

祝你好运

相关问题 更多 >