ruby-on-rails - rails unique 多对多关系

标签 ruby-on-rails ruby join unique

我正在使用 Rails 4 并使用 :has_many :through 建立多对多关系,我试图确保连接是唯一的,这样特定的电影和标签就不会相互连接不止一次。通过使用 validates_uniqueness_of 我在两次保存之间实现了这一点,但是如果在一次更新中添加了两个或更多相同的标签,则无法确保唯一性。请在下面找到相关代码:

class Film < ActiveRecord::Base
  has_many :film_tags, inverse_of: :film, dependent: :destroy
  has_many :tags, -> {uniq}, through: :film_tags

  accepts_nested_attributes_for :film_tags, allow_destroy: true
end

class FilmTag < ActiveRecord::Base
  belongs_to :film, inverse_of: :film_tags
  belongs_to :tag, inverse_of: :film_tags, counter_cache: true

  validates_uniqueness_of :tag_id, scope: :film_id, message: "duplicate tag"
end

class Tag < ActiveRecord::Base
  has_many :film_tags, inverse_of: :tag, dependent: :destroy
  has_many :films, -> {uniq}, through: :film_tags

  validates_uniqueness_of :name
end

我已经尝试将 before_save 添加到电影中,其中 film.film_tags.uniq 对其运行(也尝试过 uniq{ |film_tag| film_tag.tag_id}) 但这只会删除所有 film_tag 加入,但 1 即使某些标签没有重复也是如此。

任何人都可以就此问题提供帮助吗?或者,如果需要更多信息,请询问。

最佳答案

发生这种情况是因为唯一性验证试图找到重复的记录,在这种情况下,对于两个标签,实际数据库中都没有记录。因此,两者都通过了验证并在数据库中创建了标签。

我过去遇到过类似的问题。

但是我已经使用了下面博客中提到的方法。

https://techbrownbags.wordpress.com/2014/02/05/rails-validation-of-cocoon-nested-forms/

希望对您有所帮助。

关于ruby-on-rails - rails unique 多对多关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27954515/

相关文章:

javascript - jQuery 将动态创建的变量传递给另一个函数

ruby-on-rails - Rails simple_fields_for 无法隐藏 :id

ruby - 在 Ant build.xml 中使用 Compass 编译 SASS

ruby-on-rails - Ruby on Rails : Insert value into database based on user input?

Mysql 查询计数或家长记录

mysql - 具有复杂连接的 Rails 和查询 : Can each joined table have an alias?

ruby-on-rails - 有没有办法在 Rails 中一次检查所有 Controller 变量?

ruby-on-rails - 执行 sql 查询并循环遍历 rails 中的结果集

ruby-on-rails - 如何使用实例变量测试部分

sql join - 仅从第二个表中选择第一行