0

我有两个模型 Post 和 UserBookmarks。

项目/App1的models.py

from App2 import UserBookmarks

class Post(models.Model):
        id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
        author = models.ForeignKey(User, on_delete=models.CASCADE)
        title = models.CharField(verbose_name="Title", max_length=20)
        content = models.TextField(verbose_name="Post Content", max_length=2000)
        ...
        bookmarks = GenericRelation(UserBookmarks, related_query_name='post')

项目/App2的models.py

bookmarkable_models = models.Q(app_label='App', model='post') | models.Q(app_label='App', model='model-b') | models.Q(app_label='App', model='model-c')

class UserBookmarks(models.Model):
    id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
    user = models.ForeignKey(User, on_delete=models.CASCADE, null=False, blank=False)
    content_type = models.ForeignKey(ContentType, limit_choices_to=bookmarkable_models, on_delete=models.CASCADE, null=True, blank=False)
    object_id = models.CharField(max_length=50, blank=False)
    content_object = GenericForeignKey('content_type', 'object_id')
    date_added = models.DateTimeField(auto_now_add=True, blank=False)

现在我想检查用户是否已经将帖子作为我的views.py 添加到他的书签中,但我不明白我对此的查询应该是什么样子。目前我正在做这样的事情:

def post_add_bookmark(request, pk):
    post = get_object_or_404(Post, pk=pk)
    if request.method == 'GET':
        if post.bookmarks.filter(user=request.user).exists():
            messages.error(request,
                           'You already added this Post to your Bookmarks')
            return redirect('post_detail', pk=post.pk)
        else:
            post.bookmarks.create(user=request.user, object_id=post.pk)
            messages.success(request, 'Post has been added to your Bookmarks')
            return redirect('post_detail', pk=post.pk)
    else:
        messages.error(request, 'Something went wrong')
        return redirect('post_detail', pk=post.pk)

能 向我解释这个查询必须是什么样子才能检查它是否已经存在。目前我收到以下错误:

无法查询“peter123”:必须是“UserBookmarks”实例。

4

1 回答 1

0

您可以通过post以下方式检查用户是否已将其添加为书签:

post.bookmarks.filter(user=request.user).exists()

然而,在数据库级别强制执行此操作可能是一个好主意,这样根本不可能为同一用户存储相同的书签:

class UserBookmarks(models.Model):
    # …

    class Meta:
        constraints = [
            models.UniqueConstraint(fields=['user, content_type', 'object_id'], name='unique_bookmark')
        ]

或在之前:

class UserBookmarks(models.Model):
    # …

    class Meta:
        unique_together = [['user, content_type', 'object_id']]
于 2020-04-04T09:36:43.103 回答