2016-03-01 93 views
0

我一直在Django工作了一段时间,现在我遇到了这个奇怪的问题。Django模型不能保存查询

我在流网站增加一个等级的功能,为此,我写了一个是通过URL称为视图:

url(r'^channel/rate/(?P<stream_id>[\d]*)/(?P<rate>[\d]*)/?$', 'eros.streaming.views.view_rate_channel', 
    name='view_rate_channel'), 

def view_rate_channel(request,stream_id,rate): 
    if(stream_id and rate and request.user.is_authenticated()): 
     stream= Stream.objects.get(id=stream_id) 
     if stream not in request.user.channel.rated_streams.all(): 
      if stream.channel.user != request.user: 
       channel=Channel.objects.get(stream=stream) 
       channel.rating= channel.rating+int(rate)  
       print("channel rating: "+str(channel.rating)) 
       #this prints fine in any case 
       channel.n_voters = channel.n_voters +1 
       channel.save() 
       stream.rating= stream.rating+int(rate) 
       stream.n_voters= stream.n_voters+1 
       stream.save()  
       request.user.channel.rated_streams.add(stream) 
       request.user.channel.save() 
       return HttpResponseRedirect('/channel/'+str(stream.channel.id)+'/') 
    return HttpResponseRedirect('/channel/'+str(stream.channel.id)+'/') 

当我检查了数据库,改变我的频道即将播出channel.save()之后的对象没有保存,只有Stream对象发生了奇怪的变化。

所以做一些调试完毕后,我决定发表评论这个如果我使用,因此用户不能率流不止一次:

 ##if stream not in request.user.channel.rated_streams.all(): 

而且现在channel.save()的工作!坏事是我不能让用户不止一次地评价一个流。

继承人的模型的简化版本:

class Channel(models.Model): 
    user = models.OneToOneField(User) 
    rating = models.IntegerField(default=0) 
    n_voters = models.IntegerField(default=0) 
    rated_streams = models.ManyToManyField('Stream', related_name="rated_streams") 
    description = models.TextField(default="") 

class Stream(models.Model): 
    ## I think that maybe this relation is what is causing me trouble (?): 
    channel = models.ForeignKey(Channel) 
    rating = models.IntegerField(default=0) 
    n_voters = models.IntegerField(default=0) 

有什么不好的做法或坏的查询,我做的是正在发生的呢?提前致谢。

+0

虽然'if stream'条件未注释,'Channel'对象中的更改没有得到保存。这是问题吗? –

+0

是的你是对的 –

+0

'Channel.objects.get(stream = stream)'是如何工作的?没有'stream'列是你的'Channel'模型。 –

回答

0

使用channel = stream.channel代替channel = Channel.objects.get(stream=stream)修复了此问题。

+0

这将允许执行其他行,例如channel.rating = channel.rating + int(rate),这只有在用户还没有对流进行评级时才会发生。 –

+0

一个频道有许多流,每次用户对一个流进行评价时,它也会对频道进行评价,但一个流只能评分一次。用户可以评价频道的许多流。 –

+0

如果用户要求'stream'已经被用户评分,我们是否应该改变'channel' rate(跳过流中的改变)? –