я хочу считать комментарии к каждому посту
в моделях.py:
class Post(models.Model):
body = models.TextField(max_length=10000)
date = models.DateTimeField(auto_now_add=True, blank=True)
user = models.ForeignKey(User, on_delete=models.CASCADE)
liked_by = models.ManyToManyField(User, blank=True, related_name='liked_by')
class Meta:
ordering = ['-date']
class Comment(models.Model):
body = models.TextField(max_length=1000)
date = models.DateTimeField(auto_now_add=True, blank=True)
user = models.ForeignKey(User, on_delete=models.CASCADE)
post = models.ForeignKey(Post, on_delete=models.CASCADE)
class Meta:
ordering = ['-date']
в сериализаторах.py:
class CommentSerializer(serializers.ModelSerializer):
class Meta:
model = Comment
fields = '__all__'
class PostSerializer(serializers.ModelSerializer):
#comments = CommentSerializer()
user = UserSerializers()
total_likes = serializers.SerializerMethodField()
liked_by = SimpleUserSerializer(many=True, read_only=True)
total_comments = serializers.SerializerMethodField()
class Meta:
model = Post
fields = ('body','date','user', 'total_likes', 'liked_by','total_comments')
def get_total_likes(self, instance):
return instance.liked_by.count()
def get_total_comments(self, instance):
return instance.comments.count()
когда я запускаю этот код, он показывает, AttributeError: объект «Post» не имеет атрибута «комментарии».
как считать комментарии к посту?
Поскольку вы не настроили related_name, Django использует значение по умолчанию related_name
, и, следовательно, вы должны получить доступ к reveres FK, используя comment_set
вместо comments
Таким образом, метод get_total_comments(...)
должен выглядеть так
def get_total_comments(self, instance):
return instance.comment_set.count()
сэр, это работает. я переименовываю название модели. но не совершал миграций
сэр, это не работает. показывает, django.db.utils.ProgrammingError: отношение "fb_comment" не существует LINE 1: SELECT COUNT(*) AS "__count" FROM "fb_comment" WHERE "fb_com... имя моего приложения - fb