- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
背景:
我正在尝试创建一个系统,允许用户对其他用户撰写的评论进行投票(类似于 Reddit)。用户可以选择三个投票值:-1、0 或 1。我创建了一个 POST API(使用 django Rest-framework),它将存储用户对特定评论的投票。如果用户已经对给定的评论进行了投票,那么它将把现有用户的投票值更新为新的投票值。
我从这篇文章中汲取了灵感:Django RF update_or_create
问题:
一旦评论让一个用户对其进行投票,每当另一个用户对同一评论进行投票时,Django 都会创建一个具有相同 ID/主键的重复评论对象。我截取了我的管理页面的屏幕截图,其中显示我有 3 个对象可供选择,但只有一条评论。为什么会这样做以及如何防止它?
Screenshot of my comment admin page
我是 Django 新手。我怀疑当我在序列化器中定义自己的“创建”方法时,我可能做错了什么。我将不胜感激任何帮助。谢谢!
models.py:
评论模型:
class Comment(models.Model):
location_property_category = models.ForeignKey('locations.LocationPropertyCategory',on_delete=models.CASCADE,related_name='comments',null=True)
author = models.ForeignKey('auth.User',on_delete=models.PROTECT,related_name='comments')
location = models.ForeignKey('locations.Location',on_delete=models.CASCADE,related_name='comments')
text = models.TextField()
create_date = models.DateTimeField(default=timezone.now())
published_date = models.DateTimeField(blank=True,null=True)
approved_comment = models.BooleanField(default=False)
objects = CommentManager()
def approve(self):
self.approved_comment = True
self.save()
def __str__(self):
return self.text
def save(self, *args, **kwargs):
if self.approved_comment is True:
self.published_date = timezone.now()
super(Comment, self).save(*args, **kwargs)
def sum_vote(self):
return self.upvotedownvotes.aggregate(Sum('vote')).get('vote__sum') or 0
投票模型:
class UpVoteDownVote(models.Model):
UPVOTE = 1
NEUTRALVOTE = 0
DOWNVOTE = -1
VOTES = (
(UPVOTE, 'Upvote'),
(NEUTRALVOTE, 'Neutralvote'),
(DOWNVOTE, 'Downvote')
)
vote = models.SmallIntegerField(choices=VOTES)
user = models.ForeignKey('auth.User', related_name='upvotedownvotes', on_delete=models.CASCADE)
comment = models.ForeignKey(Comment, related_name='upvotedownvotes', on_delete=models.CASCADE)
date_voted = models.DateTimeField(default=timezone.now())
class Meta:
unique_together = (('user','comment'),)
评论管理器模型:
class CommentManager(models.Manager):
def get_queryset(self):
return super(CommentManager, self).get_queryset().order_by('-upvotedownvotes__vote')
序列化器.py投票序列化器:
class UpVoteDownVoteSerializer(serializers.ModelSerializer):
class Meta:
model = UpVoteDownVote
fields = ('vote','comment')
def get_fields(self):
fields = super(UpVoteDownVoteSerializer, self).get_fields()
fields['comment'].queryset = Comment.objects.filter(approved_comment=True)
return fields
def create(self, validated_data):
votedata, created = UpVoteDownVote.objects.update_or_create(
user=validated_data.get('user', None),
comment=validated_data.get('comment', None),
defaults={'vote': validated_data.get('vote', None),
})
return votedata
views.py
class UpVoteDownVoteCreateApiView(generics.CreateAPIView):
serializer_class = UpVoteDownVoteSerializer
permission_classes = [IsAuthenticated]
def perform_create(self,serializer):
serializer.save(user=self.request.user)
评论应用admin.py
class CommentAdmin(admin.ModelAdmin):
readonly_fields = ('id',)
admin.site.register(Comment,CommentAdmin)
最佳答案
欢迎来到 StackOverflow!
您的问题在 CommentManager
中:
queryset.order_by('-upvotedownvotes__vote')
此查询基本上创建LEFT_OUTER_JOIN
。所以你的结果看起来像:
comment#1 upvote#1
comment#1 upvote#2
comment#1 upvote#3
这就是您看到评论#1 3 次的原因。
我相信你想使用这样的东西:https://docs.djangoproject.com/en/2.1/topics/db/aggregation/#order-by
关于Django 休息 update_or_create,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53340774/
我有一个模型:- class XYZ(models.Model): unique_col = models.CharField(max_length=255) total = mode
我有一个名称字段为“jule”的用户。如果我尝试使用完全相同的名称来更新它: obj, created = Person.objects.update_or_create(first_name='ju
我在 Django 中使用以下模型: class sfs_upcs(models.Model): upc = models.CharField(max_length=14, unique=True
背景: 我正在尝试创建一个系统,允许用户对其他用户撰写的评论进行投票(类似于 Reddit)。用户可以选择三个投票值:-1、0 或 1。我创建了一个 POST API(使用 django Rest-f
大家好,我被这个问题困住了。我知道 update_or_create 应该更新已经存在的字段但它正在覆盖我正在创建或更新的数据字段。示例: class Branch(models.Model):
我有一个在 celery 中运行的 period_task 查询最新的加密货币价格,但出于某种原因,每次想要显示数据时,我都没有得到更新的记录,我只是得到了新的记录,而由于某种原因,旧的记录被保留了下
最近我在 update_or_create 中遇到问题方法。我先给大家一个完整的解释。 型号: class TransactionPageVisits(models.Model): trans
我发现 django 1.7 现在支持查询集中的 update_or_create() 方法。但当我尝试时,它不起作用。当我尝试这样做时没有创建任何对象: models.py class Model
这是我的设置模型...基本上我将设置存储为多行中的键值对 class Settings(models.Model): key = models.CharField(max_length=50
我在将 GenericRelation 与 update_or_create 结合使用时遇到问题。我有以下型号: class LockCode(TimeStampedModel): conte
AFAIK Django 不提供查看数据是否被 update_or_create() 更改的通用方法。 bool 值 created告诉我创建了一行。但是我怎么知道数据是否已更改(更改数据的 SQL
我正在使用 Django Rest 框架。如果记录不存在,我想创建它;如果存在,我想更新它。 我做了什么: class MyModelList(generics.ListCreateAPIView):
我有一个非常简单的模型: from django.contrib.postgres.fields import IntegerRangeField from django.db import mode
我正在执行 update_or_create 查询集操作,该操作在内部使用 get 查询集操作。我已经通读了有关 update_or_create 查询集方法的文档,但在理解与外键相关的部分以及将对象
代码: class OTP(AppModel): phone_regex = RegexValidator(regex=r'^[6789]\d{9}$', message="phone no.
我有两个应该始终一起创建的相关实例。我想在不使用信号或覆盖模型的 save() 的情况下执行此操作方法。 class Car(models.Mode): make = models.CharF
假设我们有一个包含以下字段的钱包表:id、user_id、total、freeze、active、update_time。 每个用户在该表中只有一条记录,并且会一直更新。 例如 { id: 1
假设我们有一个包含以下字段的钱包表:id、user_id、total、freeze、active、update_time。 每个用户在该表中只有一条记录,并且会一直更新。 例如 { id: 1
因此,我正在使用 Django update_or_create API 来构建我的表单数据。它工作正常...但是,一旦构建,我需要一种方法来检查哪些配置文件实际更新了或者它们是否是第一次创建的? 举
我正在使用 $util.autoId() 并想知道是否有一种模式可以执行 update_or_create()(类似于 Django 的模式)使用 VTL 或者我是否应该将 Resolver 链接到
我是一名优秀的程序员,十分优秀!