私はこれらmodels
を持っていて、テーブルに保存する方法を見つけようとして一晩中燃やしましたLikes
が、うまくいきません.
class Users(models.Model):
email = models.EmailField()
name = models.CharField(max_length=60)
class Posts(models.Model):
user_id = models.ForeignKey('Users')
content = models.CharField(max_length=480)
class Likes(models.Model):
post_id = models.ForeignKey('Posts', related_name='likes_set')
user_id = models.ForeignKey('Users')
status = models.IntegerField()
本当にuser_id1 = 1
テーブルに存在し、post_id11 = 11
また存在し、このユーザーがこの投稿をクリックします。
今、Likes テーブルに保存したいのですが、これが私がしたことです。
user = Users.objects.get(id = user_id1)
post = user.posts_set.get(id = post_id11)
try:
liked = post.likes_set.get(user_id = user_id1)
except Likes.DoesNotExist:
liked = None
if liked:
liked.status = F('status') - 1
liked.save()
total_likes = liked.status
return HttpResponse(total_likes)
else:
post.likes_set.create(user_id = user_id1, post_id = post_id11, status = 1)
post.likes = F('likes') + 1
post.save()
total_likes = post.likes
return HttpResponse(total_likes)
そして、これはエラーです:
ValueError at /myapp/likeRecorder/
Cannot assign "1": "Likes.user_id" must be a "Users" instance.
私はこれを解決しようとして一晩中グーグルで検索しました。ヘルプ!