0

私はこれら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.

私はこれを解決しようとして一晩中グーグルで検索しました。ヘルプ!

4

2 に答える 2