5

我有帖子的投票和投票表。我可以验证投票和否决模型中的唯一性,以确保用户不能多次投票或否决。我想验证这两个模型的唯一性,以便用户不能投票反对他们已经投票的帖子,反之亦然。我已经尝试了自定义验证,userfaved,定义如下,但它不起作用。

 class Vote < ActiveRecord::Base

 validates_uniqueness_of :user_id,  :scope => :article_id #allows only one vote

 validate :userfaved

 def userfaved
  if Votedown.where( :user_id => :user_id, :artcle_id => :article_id).any?
      errors.add(:user_id, 'already voted on this') 
  end
 end



class Votedown < ActiveRecord::Base

validates_uniqueness_of :user_id, :scope => :article_id #allows only one votedown

validate :userfaved

def userfaved
    if Vote.where(:user_id=> :user_id, :article_id => :article_id).any?
        errors.add(:user_id, 'already voted on this')
    end
end
4

1 回答 1

2

看起来您的验证中有一个错误:您传递给的哈希值where是符号。将其更改为以下内容,它应该可以工作:

Votedown.where( :user_id => self.user_id, :article_id => self.article_id).any?

但我认为有一种更简单的方法可以做到这一点。您能否只拥有一个表Votes并为其添加一个属性来记录它是向上还是向下?这将使您的唯一性检查非常简单。如果你真的想要单独的类,你可以使用单表继承:有一个votes表,一个超类Vote和两个子类,VoteUpVoteDown.

于 2012-04-06T22:04:15.627 回答